vue-cli中配置webpack系列文章五 ------ webpack.base.conf.js

webpack.base.conf.jshtml

var path = require('path')
  var utils = require('./utils')
  var config = require('../config')
  var vueLoaderConfig = require('./vue-loader.conf')
  // 獲取根目錄
  function resolve(dir) {
    return path.join(__dirname, '..', dir)
  }
  module.exports = {
    // 定義入口文件
    entry: {
      app: './src/main.js'
    },
    output: {
      // 輸出路徑
      path: config.build.assetsRoot,
      // 輸出文件名稱(name爲entry中定義的key值)
      filename: '[name].js',
      // 靜態資源路徑(判斷目前所處的環境)
      // 在開發環境下,路徑爲根目錄
      // 在生產環境下,路徑爲根目錄下的static文件夾
      publicPath: process.env.NODE_ENV === 'production' ? config.build.assetsPublicPath : config.dev.assetsPublicPath
    },
    resolve: {
      // 自動解析拓展,能夠在引用文件的時候不用寫後綴
      extensions: ['.js', '.vue', '.json'],
      // 配置別名,避免在結構嵌套過深的狀況下出現../../../../xxx這種寫法
      alias: {
        'vue$': 'vue/dist/vue.esm.js',
        '@': resolve('src')
      }
    },
    module: {
      // 配置不一樣模塊處理規則
      rules: [{
        test: /\.vue$/,
        loader: 'vue-loader',
        options: vueLoaderConfig
      }, {
        test: /\.js$/,
        loader: 'babel-loader',
        include: [resolve('src'), resolve('test')]
      }, {
        // 對於圖片資源,當文件體積小於10kb時,將其生成爲base64,直接插入html中
        // 當大於10kb時,將圖片名稱進行按照命名規則進行更改
        test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: utils.assetsPath('img/[name].[hash:7].[ext]')
        }
      }, {
        // 字體資源打包規則,與圖片資源相同
        test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
        loader: 'url-loader',
        options: {
          limit: 10000,
          name: utils.assetsPath('fonts/[name].[hash:7].[ext]')
        }
      }]
    }
  }
相關文章
相關標籤/搜索