微信小程序代码模板_vue 项目常用加载器及配置详

vue 项目常用加载器及配置详解       本文介绍了vue 项目常用加载器及配置详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

1.安装sass:

1.1 由于sass-loader依赖于node-sass,所以在安装sass-loader的同时还需安装node-sass

npm install --save-dev node-sass
npm install --save-dev sass-loader

1.2 安装完成后修改 style 标签:

 style lang="scss" /style 

2.安装axios:

axios用于数据请求,在Vue1.0的时候有一个官方推荐的 ajax 插件 [vue-resource](),但是自从 Vue 更新到 2.0 之后,官方就不再更新 vue-resource,推荐使用axios。

2.1 安装:

npm install axios --save-dev

2.2. 在main.js中引入:

import axios from 'axios'
Vue.prototype.$http = axios

2.3. 在组件中使用:

this.$http({
 method:'get',
 url:'api/artcile',
 params:{
 platformCode:'pc' // 用于向后台传参
}).then(response = {
 console.log(response)

3.安装mock:

3.1. 安装:

npm install mockjs --save-dev

3.2. 使用:在src下新建mock.js文件

import Mock from 'mockjs';
export default Mock.mock('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: '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-loader 

4.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-loader

5.2 在main.js中引入

import 'lib-flexible'

5.3 配置px2rem-loader: (在build/untils.js)

在文件中找到这句注释

<]()

在注释上面添加如下函数:

 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')
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持凡科。




扫描二维码分享到微信