手撕vue-cli配置——utils.js篇

utils.js文件主要是用來處理各類css loader的,好比css-loader,less-loader等。css

//引入path模塊
const path = require('path')

//引入以前的config模塊
const config = require('../config')

//引入「extract-text-webpack-plugin」,它的做用是打包後將生成css文件經過link的方式引入到html中,若是不使用這個插件,那麼css就打包到<head>的style中
const ExtractTextPlugin = require('extract-text-webpack-plugin')

//引入package.json
const pkg = require('../package.json')

 

exports.assetsPath = function (_path) {
//結合config文件的代碼能夠知道,當環境爲生產環境時,assetSubDirectory爲「static」,開發環境也是「static」  
  const assetsSubDirectory = process.env.NODE_ENV === 'production'
    ? config.build.assetsSubDirectory
    : config.dev.assetsSubDirectory  
  
// path.posix.join()是path.join的一種兼容性寫法,它的做用是路徑的拼接,好比path.posix.join("/c/aa',"bb"); // "c/aa/bb"
  return path.posix.join(assetsSubDirectory, _path)
}

 

//用來生成Loader的函數 ,自己能夠用在vue-loader的配置上(vue-loader.config.js文件,之後我會提這個文件),同時也是爲styleLoader函數使用(後面說)
exports.cssLoaders = function (options) {
  //若是沒有傳參就默認空對象
  options = options || {}

  //配置css-loader,css-loader能夠讓處理css中的@import或者url()
  const cssLoader = {
    loader: 'css-loader',
    options: {
      sourceMap: options.sourceMap
    }
  }
  //配置postcss-loader,主要功能是補全css中的兼容性前綴,好比「-webkit-」等
  var postcssLoader = {
    loader: 'postcss-loader',
    options: {
      sourceMap: options.sourceMap
    }
  }

  //生成loader的私有方法
  function generateLoaders (loader, loaderOptions) {
    //參數的usePostCss屬性是否爲true,是就使用兩個loader,不然只使用css-loader
    const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]
    if (loader) {
      //給generateLoaders傳loader參數的話,好比「less或者sass」,就將這個loader的配置傳到loaders數組中
      loaders.push({
        loader: loader + '-loader',
        //Object.assign()是es6的語法,用來合併對象
        options: Object.assign({}, loaderOptions, {
          sourceMap: options.sourceMap
        })
      })
    }

    //若是options參數的extract屬性爲true,就使用extract text plugin將css抽成單獨的文件,不然就將css寫進style裏
    if (options.extract) {
      return ExtractTextPlugin.extract({
        use: loaders,
        //vue-style-loader能夠理解爲vue版的style-loader,它能夠將css放進style中
        fallback: 'vue-style-loader'
      })
    } else {
      return ['vue-style-loader'].concat(loaders)
    }
  }

  
  return {
    //返回各類loader
    css: generateLoaders(),
    postcss: generateLoaders(),
    less: generateLoaders('less'),
    sass: generateLoaders('sass', { indentedSyntax: true }),
    scss: generateLoaders('sass'),
    stylus: generateLoaders('stylus'),
    styl: generateLoaders('stylus')
  }
}
 
 
//生成開發環境下loader的配置,使用在(webpack.dev.conf.js中)
exports.styleLoaders = function (options) {
  const output = []
  //調用cssLoaders方法,返回loaders的對象
  const loaders = exports.cssLoaders(options)
  //遍歷每個loader,並配置成對應的格式,傳給output數組
  for (const extension in loaders) {
    const loader = loaders[extension]
    output.push({ 
      test: new RegExp('\\.' + extension + '$'),
      use: loader
    })
  }
  return output
}
相關文章
相關標籤/搜索