时间:2021-05-26
本文介绍了vue 项目常用加载器及配置详解,分享给大家,具体如下:
1.安装sass:
1.1 由于sass-loader依赖于node-sass,所以在安装sass-loader的同时还需安装node-sass
npm install --save-dev node-sassnpm install --save-dev sass-loader1.2 安装完成后修改 <style>标签:
<style lang="scss"></style>2.安装axios:
axios用于数据请求,在Vue1.0的时候有一个官方推荐的 ajax 插件 [vue-resource](https://github.com/pagekit/vue-resource),但是自从 Vue 更新到 2.0 之后,官方就不再更新 vue-resource,推荐使用axios。
2.1 安装:
npm install axios --save-dev2.2. 在main.js中引入:
import axios from 'axios'Vue.prototype.$http = axios2.3. 在组件中使用:
this.$http({ method:'get', url:'http://breadoffer.com/api/artcile', params:{ platformCode:'pc' // 用于向后台传参 }}).then(response => { console.log(response)})3.安装mock:
3.1. 安装:
npm install mockjs --save-dev3.2. 使用:在src下新建mock.js文件
import Mock from 'mockjs';export default Mock.mock('http://platform.breadoffer.com/api/oversea', { "data":{ "breadActivities|9":[{ "title":"@csentence(5,25)", "desc":"@paragraph(2)", "beiginTime":"@date", "endTime":"@date", "stateName":"进行中", }], }})3.3. 在需要数据的组件中引入:
import datas from '../mock' // 根据自己实际目录引入 methods: { request() { this.$http({ method: 'get', url: 'http://platform.breadoffer.com/api/oversea', params: { courseMaxCount: 2, //设置课程返回的数据为2条 teacherMaxCount: 10, //设置导师返回的数据为10条 } }).then(response => { console.log(response) }).catch(error => { console.log(error) }) }, }4.安装 lib-flexible: --实现移动端自适应
4.1 安装:
npm install lib-flexible --save在实际开发过程中,使用flexible插件时会自动把px转换成rem单位,在vue项目中我们使用px2rem这个工具进行转换,所以需要安装px2rem加载器:
npm install px2rem-loader4.2 在main.js中引入:
import 'lib-flexible'4.3 配置px2rem-loader: (在build/untils.js)
remUnit 的意思是1rem=多少像素, 结合lib-flexible,我们将px2remLoader的option.remUnit 设置成设计稿宽度的1/10,假设我们的设计稿宽度是750,则remUnit为75,然后在cssLoader后面加一个px2remLoader即可
var px2remLoader = { loader: 'px2rem-loader', options: { remUnit: 75 } } // generate loader string to be used with extract text plugin function generateLoaders (loader, loaderOptions) { const loaders = [cssLoader,px2remLoader] if (loader) { loaders.push({ loader: loader + '-loader', options: Object.assign({}, loaderOptions, { sourceMap: options.sourceMap }) }) }5.安装 sass-resourses-loader
如果在项目中使用sass,或多或少会用到全局的变量,mixin/function等,那么如何将其设为全局状态,以避免在每个vue文件中引入?
5.1 安装 sass-resources-loader:
npm i sass-resources-loader5.2 在main.js中引入
import 'lib-flexible'5.3 配置px2rem-loader: (在build/untils.js)
在文件中找到这句注释
// [https://vue-loader.vuejs.org/en/configurations/extract-css.html](https://vue-loader.vuejs.org/en/configurations/extract-css.html)
在注释上面添加如下函数:
function resolveResouce(name) { return path.resolve(__dirname, '../src/sass/' + name); // sass文件所在目录 } function generateSassResourceLoader() { var loaders = [ cssLoader, // 'postcss-loader', 'sass-loader', { loader: 'sass-resources-loader', options: { // it need a absolute path resources: [resolveResouce('_mixin.scss')] } } ]; if (options.extract) { return ExtractTextPlugin.extract({ use: loaders, fallback: 'vue-style-loader' }) } else { return ['vue-style-loader'].concat(loaders) } }并且将以下代码
// return { // css: generateLoaders(), // postcss: generateLoaders(), // less: generateLoaders('less'), // sass: generateLoaders('sass', { indentedSyntax: true }), // scss: generateLoaders('sass'), // stylus: generateLoaders('stylus'), // styl: generateLoaders('stylus') // }替换为:
return { css: generateLoaders(), postcss: generateLoaders(), less: generateLoaders('less'), sass: generateSassResourceLoader(), scss: generateSassResourceLoader(), stylus: generateLoaders('stylus'), styl: generateLoaders('stylus') }以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
这次给大家带来vue-cli3.0配置详解,使用vue-cli3.0配置的注意事项有哪些,下面就是实战案例,一起来看一下。新建项目#安装npminstall-g
AndroidonLoadFinished与onLoaderReset回调详解及实例onLoadFinished这个方法是在前面已创建的加载器已经完成其加载过程
这次给大家带来vue-cli3.0配置及使用详解,写给需要的朋友。VueCLI是一个基于Vue.js进行快速开发的完整系统,提供:通过@vue/cli搭建交互式
使用vue的同学们大都是基于vue-cli来搭建项目的,vue-cli中的配置全面强大。//常用的命令npmrundev//本地热更新模式npmrunbuild
java详解类加载器的双亲委派及打破双亲委派一般的场景中使用Java默认的类加载器即可,但有时为了达到某种目的又不得不实现自己的类加载器,例如为了达到类库的互相