当前位置: 移动技术网 > IT编程>脚本编程>vue.js > vue 项目常用加载器及配置详解

vue 项目常用加载器及配置详解

2018年01月31日  | 移动技术网IT编程  | 我要评论

欺辱尤娜小游戏,湖北多地受灾,nwiz是什么

本文介绍了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:'http://breadoffer.com/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('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-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)

在文件中找到这句注释

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

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网