webpack实用配置

前面的话

  上文介绍了webpack入门,本文将详细介绍webpack实用配置

版本号

  以entry.js打包为bundle.js为例,出口的filename可以设置为[id]、[name]、[hash]、[chunkhash]等替换形式,如下所示

var webpack = require(‘webpack‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘[id]-[name]-[hash].js‘//出口名称
  }
}

  则出口文件为0-main-0c1dce21f6c5db455fb4.js

  如果index.html要引用打包后的js文件,由于文件名称不确定,并不好解决。这时,就需要使用html-webpack-plugin插件。该插件并不是内置插件,所以需要安装

npm install html-webpack-plugin

  HtmlWebpackPlugin简化了HTML文件的创建,以便为webpack包提供服务。这对于在文件名中包含每次会随着变异会发生变化的哈希的webpack bundle尤其有用

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: ‘match‘,//生成的html文件的标题为‘match‘
      filename: ‘index.html‘//生成的html文件名称为‘index.html‘
    })
  ]
}

  通过以上的配置,如果在当前路径,index.html不存在,则生成;如果存在,则替换

  [注意]如果htmlwebpackplugin不进行配置,参数为空, plugins: [new HtmlWebpackPlugin()]。默认地,生成的html文件名称为‘index.html‘,标题为‘Webpack APP‘

【标签位置】

  htmlwebpackplugin插件的常用设置是设置script标签插入的位置,默认插入到body标签中,但可以使用inject:‘head‘,设置插入到head标签中

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      inject:‘head‘,//将script标签插入到head标签中
      filename: ‘index-[hash].html‘,//生成的html文件名称为‘index.html‘
    })
  ]
}

【图标设置】

  设置favicon属性,可以设置网页的小图标

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      favicon:‘./icon.ico‘
    })
  ]
}

【压缩】

  设置minify属性,可以压缩html文件,默认为false,即不压缩

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      minify:{
          removeComments: true,//删除注释
          collapseWhitespace:true//删除空格
      }
    })
  ]
}

  使用webpack打包后的index.html代码如下

<!DOCTYPE html><html><head><meta charset="UTF-8"><title>Webpack App</title></head><body><script type="text/javascript" src="js/0-main-8128c0c26a4449da7a05.js"></script></body></html>

模板文件

  HtmlWebpackPlugin除了提供模块版本号的功能,还可以使用模板文件

  例如,模板文件为template.html,内容如下

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>template</title>
</head>
<body>
<script src="test.js"></script>
<div>test</div>
</body>
</html>

  webpack配置文件如下

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      filename: ‘index-[hash].html‘,//生成的html文件名称为‘index.html‘
      template:‘template/template.html‘//模板文件为‘template.html‘
    })
  ]
}

  生成的index-[hash].html以‘template.html‘文件为模板

  [注意]如果在htmlwebpackplugin中使用了模板,则指定title不会生效,因为要以模板的title为准  

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      title:‘test‘,
      filename: ‘index-[hash].html‘,//生成的html文件名称为‘index.html‘
      template:‘template/template.html‘//模板文件为‘template.html‘
    })
  ]
}

【传参】

  模块文件当然是可以传参的,一般地,使用ejs语法。例如,在模板文件中,使用<%= htmlWebpackPlugin.options.title %>,即可读取htmlWebpackPlugin插件中‘title‘属性的值

  [注意]模板文件中的‘htmlWebpackPlugin‘是固定的,不能随意更改。与webpack.config.js文件中,require()该插件的命名无关

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      title:‘test‘,
      template:‘template/template.html‘,//模板文件为‘template.html‘
      dateData: new Date()
    })
  ]
}
//template.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title><%= htmlWebpackPlugin.options.title  %></title>
</head>
<body>
<div><%=htmlWebpackPlugin.options.dateData %></div>
</body>
</html>

【模板组件】

  下面利用模板组件组合成一个html文件,以ejs模板语言为例

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      template:‘template/template.html‘})
  ]
}
//template.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<div>
    <% include  template/header.html %>
</div>
<ul>
    <% var arr = [1,2,3,4,5] %>
    <% for(var i = 0; i < arr.length; i++){ %>
        <li><%=arr[i] %></li>
    <% } %>
</ul>
<div>
    <% include  template/footer.html %>
</div>
</body>
</html>
//header.html
<div>我是头部</div>
//footer.html
<div>我是尾部</div>

  运行结果报错,提示子模板加载失败

  这是因为HtmlWebpackPlugin插件并不具备ejs模板语言所有的功能,其中一个就是不能识别<%include %>语句,这时需要安装一个ejs-compiled-loader

npm install ejs-compiled-loader

  安装完成后,修改配置文件如下,表示使用ejs-compiled-loader来编译template.html

  [注意]该插件中的include路径相对于webpack配置文件的位置,而不是模板文件template.html的位置

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
      template:‘ejs-compiled-loader!template/template.html‘})
  ]
}

  结果如下

多页面

  对于多页面来说,一般地,有多个入口文件。不同的html页面输出对应不同的入口文件。 插件plugins()是一个数组,每new一个HtmlWebpackPlugin(),就可以输出一个html页面。这里有两个重要的属性:chunks和excludeChunks,chunks表示所包含的入口文件,excludeChunks表示要排除的入口文件

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: {
      a:‘./src/js/a.js‘,
      b:‘./src/js/b.js‘,
      c:‘./src/js/c.js‘
  },
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
          filename:‘a.html‘,
          template:‘src/template/template.html‘,
          title:‘this is a‘,
          chunks:[‘a‘]
    }),
    new HtmlWebpackPlugin({
          filename:‘b.html‘,
          template:‘src/template/template.html‘,
          title:‘this is b‘,
          chunks:[‘b‘]
    }),
    new HtmlWebpackPlugin({
          filename:‘c.html‘,
          template:‘src/template/template.html‘,
          title:‘this is c‘,
          excludeChunks:[‘a‘,‘b‘]
    }),
  ]
}

  结果如下

//a.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>this is a</title>
</head>
<body>
<div></div>
<script type="text/javascript" src="js/2-a-9828ea84bd8c12c19b5f.js"></script></body>
</html>

//b.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>this is b</title>
</head>
<body>
<div></div>
<script type="text/javascript" src="js/1-b-9828ea84bd8c12c19b5f.js"></script></body>
</html>

//c.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>this is c</title>
</head>
<body>
<div></div>
<script type="text/javascript" src="js/0-c-9828ea84bd8c12c19b5f.js"></script></body>
</html>

内联

  在前面的例子中,都是以链接的形式引入入口文件的。有时,为了追求性能,会将其处理为内联的形式。这里就需要安装一个扩展插件html-webpack-inline-source-plugin,专门用来处理入口文件内联的

$ npm install --save-dev html-webpack-inline-source-plugin

  该插件的使用很简单,使用require()语句引入后,在插件plugins()新建一个html-webpack-inline-source-plugin对象,然后在html-webpack-plugin对象中添加inlineSource属性即可

inlineSource: ‘.(js|css)$‘ // embed all javascript and css inline
//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
var HtmlWebpackInlineSourcePlugin = require(‘html-webpack-inline-source-plugin‘);

module.exports = {
  entry: ‘./entry.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  plugins: [
    new HtmlWebpackPlugin({
        inlineSource: ‘.(js|css)$‘
    }),
    new HtmlWebpackInlineSourcePlugin()
  ]
}

  结果如下

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>Webpack App</title>
  </head>
  <body>
  <script type="text/javascript">/******/ (function(modules) { // webpackBootstrap
/******/     // The module cache
/******/     var installedModules = {};
/******/
/******/     // The require function
/******/     function __webpack_require__(moduleId) {
/******/
/******/         // Check if module is in cache
/******/         if(installedModules[moduleId]) {
/******/             return installedModules[moduleId].exports;
/******/         }
/******/         // Create a new module (and put it into the cache)
/******/         var module = installedModules[moduleId] = {
/******/             i: moduleId,
/******/             l: false,
/******/             exports: {}
/******/         };
/******/
/******/         // Execute the module function
/******/         modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
/******/
/******/         // Flag the module as loaded
/******/         module.l = true;
/******/
/******/         // Return the exports of the module
/******/         return module.exports;
/******/     }
/******/
/******/
/******/     // expose the modules object (__webpack_modules__)
/******/     __webpack_require__.m = modules;
/******/
/******/     // expose the module cache
/******/     __webpack_require__.c = installedModules;
/******/
/******/     // identity function for calling harmony imports with the correct context
/******/     __webpack_require__.i = function(value) { return value; };
/******/
/******/     // define getter function for harmony exports
/******/     __webpack_require__.d = function(exports, name, getter) {
/******/         if(!__webpack_require__.o(exports, name)) {
/******/             Object.defineProperty(exports, name, {
/******/                 configurable: false,
/******/                 enumerable: true,
/******/                 get: getter
/******/             });
/******/         }
/******/     };
/******/
/******/     // getDefaultExport function for compatibility with non-harmony modules
/******/     __webpack_require__.n = function(module) {
/******/         var getter = module && module.__esModule ?
/******/             function getDefault() { return module[‘default‘]; } :
/******/             function getModuleExports() { return module; };
/******/         __webpack_require__.d(getter, ‘a‘, getter);
/******/         return getter;
/******/     };
/******/
/******/     // Object.prototype.hasOwnProperty.call
/******/     __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
/******/
/******/     // __webpack_public_path__
/******/     __webpack_require__.p = "";
/******/
/******/     // Load entry module and return exports
/******/     return __webpack_require__(__webpack_require__.s = 0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ (function(module, exports) {

document.write(‘It works.‘)

/***/ })
/******/ ]);</script></body>
</html>

babel

  下面使用babel来进行es最新标准的代码向es5代码的转换,首先需要安装babel核心程序,及babel-loader

npm install babel-loader babel-core 

  在使用babel-loader进行代码转换之前,要先了解到ecmascript标准变化很快,且浏览器支持情况不同。所以,出现了‘es2015‘、‘es2016‘、‘es2017‘、‘latest‘、‘env(new)‘等多个不同的标准。这时,要需要来选择从哪个标准进行转换,需要安装插件babel-preset-env 

npm install babel-preset-env 

  在 webpack 配置对象中,需要添加 babel-loader 到 module 的 loaders 列表中

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);

module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      loaders:[{
          test:/\.js$/,
          use:{
              loader:‘babel-loader‘,
              options:{
                  presets: [‘env‘]
              }
          }
      }]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}
//app.js
let num = 1;
console.log(num);

【打包速度】

  运行后,页面控制台输出1,转换正常。但是,babel的转换过程却很慢

  前面的博文webpack的四个基本概念,我们介绍过loader的test属性表示该loader必须满足的条件,上面代码中使用/\.js$/ 来匹配,这样也许会去转译 node_modules 目录或者其他不需要的源代码。这样会大大增加webpack的编译时间

  要排除 node_modules,就要使用 loaders 配置的 exclude 选项,表示哪些除外,exclude:/node_modules/

  [注意]exclude也应该用正则的形式,如果用__dirname +‘/node_modules‘的形式则不会生效

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);

module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      loaders:[{
          test:/\.js$/,
          exclude: /node_modules/,
          use:{
              loader: ‘babel-loader‘,
              options:{
                  presets: [‘env‘]
              }
          }
      }]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

  当然了,除了exclude选项,也有include选项,能够明确被打包的文件时,使用include将使打包速度更快

  对于include来说,它比较特别,字符串形式__dirname + ‘./src/‘和正则形式/\.\/src/都支持,经过测试,这两种形式的打包速度类似

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);

module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      loaders:[{
          test:/\.js$/,
          include:/\.\/src/,
          use:{
              loader: ‘babel-loader‘,
              options:{
                  presets: [‘env‘]
              }
          }
      }]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

 

CSS

  在webpack入门博文中由介绍过CSS插件的简单使用,接下来将详细介绍

  首先,要安装css-loader和style-loader,css-loader用于读取并加载css文件,style-loader将它插入到页面中

  [特别注意]在处理css时,最好不要使用include、exclude等属性。include、exclude属性是加快babel转换速度的,和css没什么关系,而且会添乱

npm install css-loader style-loader
//app.js
require(‘./css/common.css‘);
//common.css
body{margin: 0;background-color: red}
//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘, ‘css-loader‘ ]
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

  效果如下

【自动前缀】

  页面加载CSS往往并不像上面的情况这么简单,需要处理很多问题,其中一个就是浏览器前缀问题。对于某些属性来说,比如transform,不同浏览器的版本对其支持程度不同,浏览器前缀也不同。这时,就需要能够根据实际情况,自动增加前缀,而postcss-loader就是这样的工具,而且功能要强大的多

  首先,先安装postcss-loader

npm install postcss-loader

  然后,安装postcss的自动前缀的插件autoprefixer

npm install autoprefixer

  配置如下

//common.css
body{transform: scale(0);background-color: red}
//app.js
require(‘./css/common.css‘);
//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘,
                    ‘css-loader‘,
                    {
                        loader: ‘postcss-loader‘,
                        options: {plugins: [require(‘autoprefixer‘)]}
                    }
                 ]
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

  结果如下

  如果css文件中出现@import,则有两种处理方式,一种是将postcss文件单独写成配置文件postcss.config.js

//common.css
@import ‘./flex.css‘;
body{transform: scale(0);background-color: red}
//flex.css
body{display:flex;}
//app.js
require(‘./css/common.css‘);

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘,
                  { loader: ‘css-loader‘,
                    options: {importLoaders: 1}
                  },
                ‘postcss-loader‘
                ]
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

//postcss.config.js
module.exports = {
 plugins:[require(‘autoprefixer‘)]
}

  结果如下

  另一种需要安装postcss-import插件

npm install postcss-import
//common.css
@import ‘./flex.css‘;
body{transform: scale(0);background-color: red}
//flex.css
body{display:flex;}
//app.js
require(‘./css/common.css‘);

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘,
                  { loader: ‘css-loader‘,
                    options: {importLoaders: 1 }
                  },
                  {
                    loader: ‘postcss-loader‘,
                    options: {plugins: [
                          require(‘postcss-import‘),
                          require(‘autoprefixer‘)
                        ]
                    }
                  }
                ]
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

  结果如下

【sass】

  首先,需要安装sass-loader及node-sass

  [注意]关于node-sass安装的问题移步至此

npm install sass-loader node-sass

  由于sass-loader中已经自带了关于@import处理的问题。所以,不需要css-loader及postcss-loader的额外处理

//layer.scss
@import ‘./flex.scss‘;
body{
    background-color:green;
    div{
        width: 400px;
    }
}
//flex.scss
.flex{display:flex;}
//app.js
require(‘./components/layer/layer.scss‘);

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.scss$/,
              use:[    ‘style-loader‘,
                      ‘css-loader‘,
                    {
                        loader: ‘postcss-loader‘,
                        options: {plugins: [require(‘autoprefixer‘)]}
                    },
                    ‘sass-loader‘
                 ]
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({})
  ]
}

  结果如下

【分离CSS】

  默认地,CSS作为模块资源被打包到入口js文件中。有时,需要把CSS文件分离出来,这时就需要用到extract-text-webpack-plugin插件

npm install extract-text-webpack-plugin

  该插件的配置如下

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
var ExtractTextPlugin = require(‘extract-text-webpack-plugin‘);
module.exports = {
  entry: ‘./src/app.js‘,
  output:{
    path: __dirname,//出口路径
    filename: ‘js/[name].bundle.js‘//出口名称
  },
  module:{
      rules:[
          {
                  test:/\.scss$/,
                use: ExtractTextPlugin.extract({
                  fallback: ‘style-loader‘,
                  use:[ ‘css-loader‘,
                        {
                            loader: ‘postcss-loader‘,
                            options: {plugins: [require(‘autoprefixer‘)]}
                        },
                        ‘sass-loader‘
                     ]
                })
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({}),
    new ExtractTextPlugin("styles.css")
  ]
}

  结果如下,该插件将入口文件中引用的 *.css,移动到独立分离的 CSS 文件。因此,你的样式将不再内嵌到 JS bundle 中,而是会放到一个单独的 CSS 文件(即 styles.css)当中。 如果样式文件大小较大,这会做更快提前加载,因为 CSS bundle 会跟 JS bundle 并行加载

图片资源

  webpack在处理图片、音乐、电影等资源文件时,需要使用file-loader

npm install file-loader

  默认情况下,使用file-loader生成的文件的文件名就是文件内容的MD5哈希值并保留原始扩展名

  以引入图片资源例,有以下几种情况

  1、通过css文件的background属性引入

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  module:{

      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘, ‘css-loader‘ ]
          },
          {
              test:/\.(png|jpg|gif|svg)$/i,
              use:‘file-loader‘
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin()
  ]
}
//entry.js
require(‘./src/css/common.css‘);
//common.css
body{background: url(‘../img/eg_bulbon.gif‘)}

  结果如下

  2、通过模板html文件img标签引入,这时需要使用${require(‘‘)}将相对路径包裹一次

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘, ‘css-loader‘ ]
          },
          {
              test:/\.(png|jpg|gif|svg)$/i,
              use:‘file-loader‘
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({
        template:‘template/template.html‘
    })
  ]
}
//template.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<img src="${require(‘../src/img/eg_bulbon.gif‘)}" >
</body>
</html>

  结果如下

  3、若模板使用ejs-compiled-loader插件,则无法使用${require(‘‘)}语句,需要使用HtmlWebpackPlugin传参来构造绝对路径

//webpack.config.js
var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
module.exports = {
  entry: ‘./entry.js‘, //入口文件
  output: {
    path: __dirname + ‘/dist‘,//出口路径
    filename: ‘js/[id]-[name]-[hash].js‘//出口名称
  },
  module:{
      rules:[
          {
              test:/\.css$/,
              use:[ ‘style-loader‘, ‘css-loader‘ ]
          },
          {
              test:/\.(png|jpg|gif|svg)$/i,
              use:‘file-loader‘
          }
      ]
  },
  plugins: [
    new HtmlWebpackPlugin({
        template:‘ejs-compiled-loader!template/template.html‘,
        file:__dirname
    })
  ]
}
//template.html
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
<div>
    <% include  template/header.html %>
</div>
</body>
</html>
//header.html
<img src="<%=htmlWebpackPlugin.options.file%>\src\img\eg_bulbon.gif" >

  结果如下

【file-loader参数】

  文件名模板占位符有如下几种

[ext] 资源扩展名
[name] 资源的基本名称
[path] 资源相对于 context 查询参数或者配置的路径
[hash] 内容的哈希值,默认为十六进制编码的 md5
[<hashType>:hash:<digestType>:<length>] 可选配置
  其他的 hashType, 即 sha1, md5, sha256, sha512
  其他的 digestType, 即 hex, base26, base32, base36, base49, base52, base58, base62, base64
  length 字符的长度
[N] 当前文件名按照查询参数 regExp 匹配后获得到第 N 个匹配结果
{
  test:/\.(png|jpg|gif|svg)$/i,
  use:[{
              loader:‘file-loader‘,
            options: {
                name:‘[name]-[hash:5].[ext]‘
            }
        }]
}

  或者

{
  test:/\.(png|jpg|gif|svg)$/i,
  use:[‘file-loader?name=[name]-[hash:5].[ext]‘]
}

  结果如下

【url-loader】

  url-loader功能类似于file-loader,但是在文件大小(单位byte)低于指定的限制时,可以返回一个dataURL

  可以通过传递查询参数(query parameter)来指定限制(默认为不限制)。

  如果文件大小超过限制,将转为使用 file-loader,所有的查询参数也会传过去

npm install url-loader

  图片的大小为1.1kb,下面将限制设置为2000,则图片将以base64格式传递

{
  test:/\.(png|jpg|gif|svg)$/i,
  use:[‘url-loader?limit=2000‘]
}

  结果如下

  如果将限制大小设置为1000,图片以src的形式传递

{
  test:/\.(png|jpg|gif|svg)$/i,
  use:[{
              loader:‘url-loader‘,
            options: {
                limit:1000,
                name:‘[name]-[hash:5].[ext]‘
            }
        }]
}

【image-webpack-loader】

  使用image-webpack-loader来压缩图片

npm install image-webpack-loader

  插件一张大小为4.1kb的名称为‘m.jpg‘的图片,配置如下

{
  test:/\.(png|jpg|gif|svg)$/i,
  use:[
    ‘url-loader?limit=1000&name=[name]-[hash:5].[ext]‘,
    ‘image-webpack-loader‘
  ]
}

  结果如下所示,生成大小为3.28kb,名称为‘m-c7083.jpg‘的图片

实用配置

  下面将使用webpack搭建一个实用的开发环境

var webpack = require(‘webpack‘);
var HtmlWebpackPlugin = require(‘html-webpack-plugin‘);
var ExtractTextPlugin = require(‘extract-text-webpack-plugin‘);
module.exports = {
    entry: ‘./src/app.js‘,//入口文件
    output:{
        path: __dirname,//出口路径
        filename: ‘js/[name].bundle.js‘//出口名称
    },
    module:{
        rules:[
            {
                test:/\.scss$/,
                use: ExtractTextPlugin.extract({
                    fallback: ‘style-loader‘,
                     use:[
                             ‘css-loader‘,
                            {
                                loader: ‘postcss-loader‘,
                                //自动添加前缀
                                options: {plugins: [require(‘autoprefixer‘)]}
                            },
                            ‘sass-loader‘
                        ]
                })
            },
            {
                test:/\.js$/,
                include:/\.\/src/,
                use:{
                        loader: ‘babel-loader‘,
                        //将最新标准的js代码翻译为es5代码
                        options:{presets: [‘env‘]}
                    }
            },
            {
                test:/\.(png|jpg|gif|svg)$/i,
                use:[
                        //当图片大小大于1000byte时,以[name]-[hash:5].[ext]的形式输出
                        //当图片大小小于1000byte时,以baseURL的形式输出
                        ‘url-loader?limit=1000&name=[name]-[hash:5].[ext]‘,
                        //压缩图片
                        ‘image-webpack-loader‘
                    ]
            }
          ]
    },
    plugins: [
          //使用模板生成html文件
        new HtmlWebpackPlugin({template:‘ejs-compiled-loader!template/template.html‘}),
        //分离出css到style.css
        new ExtractTextPlugin("style.css")
    ]
}
时间: 2024-10-13 12:08:44

webpack实用配置的相关文章

webpack 实用配置总结

1.webpack.config.js配置文件为: //处理共用.通用的js var webpack = require('webpack'); //处理html模板 var htmlWebpackPlugin = require('html-webpack-plugin'); //css单独打包 var ExtractTextPlugin = require("extract-text-webpack-plugin"); // 获取html-webpack-plugin参数的方法 v

webpack安装配置使用教程详解

webpack安装配置使用教程详解 www.111cn.net 更新:2015-09-01 编辑:swteen 来源:转载 本文章来为各位详细的介绍一下关于webpack安装配置使用教程吧,这篇文章对于不喜欢使用 jspm测试的朋友可以参考一下. webpack 入门 目录 1 安装 webpack2 初始化项目3 webpack 配置4 自动刷新5 第三方库6 模块化7 打包.构建8 webpack 模板我最近大量使用的是 jspm,但因为用它搭建的前端开发环境中,写测试代码非常困难,而项目又

vue 一些webpack的配置详解

最近一直在忙着做项目 本来想养成一个经常跟新博客的习惯 , 但是实在是太难了 , 每天加班到10点多 .8点能下班都是最好的了 , 小公司真不好待呀 分享一下最近半年的vue心得吧 我的项目是在他的基础上改的 PanJiaChen/vueAdmin-template vuex 咋web上我觉得是鸡肋 , 用户刷新页面直接就没了........... 这是我的目录 , 现在我遇到一个瓶颈  , 就是如何优化 build 的速度问题 , 这个问题随着页面原来越多已经发展到越来越恐怖的地方了现在打包一

webpack详细配置解析

阅读本文之前,先看下面这个webpack的配置文件,如果每一项你都懂,那本文能带给你的收获也许就比较有限,你可以快速浏览或直接跳过:如果你和十天前的我一样,对很多选项存在着疑惑,那花一段时间慢慢阅读本文,你的疑惑一定一个一个都会消失:如果你以前没怎么接触过Webpack,而你又你对webpack感兴趣,那么动手跟着本文中那个贯穿始终的例子写一次,写完以后你会发现你已明明白白的走进了Webpack的大门. //一个常见的Webpack配置文件 var webpack = require('webp

webpack基础配置

现今的很多网页其实可以看做是功能丰富的应用,它们拥有着复杂的JavaScript代码和一大堆依赖包.为了简化开发的复杂度,前端社区涌现出了很多好的实践方法 模块化,让我们可以把复杂的程序细化为小的文件; 类似于TypeScript这种在JavaScript基础上拓展的开发语言:使我们能够实现目前版本的JavaScript不能直接使用的特性,并且之后还能转换为JavaScript文件使浏览器可以识别: Scss,less等CSS预处理器 ... 这些改进确实大大的提高了我们的开发效率,但是利用它们

Vue2+webpack+node 配置+入门+详解

Vue2介绍 1.vue2.0 Vue (读音 /vju?/,类似于 view) 是一套用于构建用户界面的渐进式框架. Vue 的核心库只关注视图层 采用单文件组件 复杂大型单页应用程序(SPA) 响应式的数据绑定,与组件化的开发 HTML中的DOM与其他的部分独立开来划分出一个层次,这个层次就叫做视图层 2.Webpack Webpack是一个前端打包和构建工具. webpack有四个核心概念: 入口(entry)指示 webpack 应该使用哪个模块,来作为构建其内部依赖图的开始.可以单个入

在webpack中配置vue.js

在webpack中配置vue.js 这里有两种在webpack中配置vue.js的方法,如下: 1.在main.js中引入vue的包: index.html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width,

深入理解webpack基本配置(一)

1. 安装webpack到全局 在学习构建之前,我们来在本地文件新建一个存放项目的文件夹,比如叫demo1这个项目,然后进入demo1该项目的根目录后,执行命令 npm init运行下,一路回车(先简单的来),就会生成一个package.json文件. 在项目中直接运行如下命令,就可以把webpack安装到全局去:如下命令: npm install -g webpack 2. 安装webpack到本项目. 在本项目中,执行如下命令,就可以把webpack安装到本地项目中,如下命令: npm in

webpack4.0:webpack基础配置

webpack安装 npm i webpack webpack-cli -D npm init -y 初始化,-y参数代表init的过程中不必敲回车,直接生成默认的package.json文件 配置webpack 默认配置文件名:webpack.config.js 新建webpack.config.js文件,配置如下: 新建src文件夹,在src下 新建index.js入口文件,随便输入点东西 执行打包命令:npx webpack,就会生成一个dist目录(为啥打包后的文件名不是我配置的bund