前端

前端面试必问之Webpack

2019-11-01  本文已影响0人  明明你也一样

概念

打包你的资源,webpack是把项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到你的项目的所有依赖文件,使用loaders处理它们,最后打包成一个或多个浏览器可识别的js文件

entry

entry: 用来指示webpack的入口文件,它将是整个依赖关系的根。webpack会从它开始帮你找到所有的依赖文件,并完成处理打包

var baseConfig = {
        entry: './src/index.js'
    }

当我们需要多个入口文件的时候,可以把entry写成一个对象

var baseConfig = {
        entry: {
            main: './src/index.js'
        }
    }

output

output: 属性告诉 webpack 在哪里输出它所创建(打包)的 bundles,以及如何命名这些文件。注意,即使入口文件有多个,但是只有一个输出配置。

var path = require('path')

var baseConfig = {
    entry: {
        main: './src/index.js'
    },
    output: {
        filename: 'main.js',
        path: path.resolve(__dirname, 'dist')
    }
}

module.exports = baseConfig

在上面的示例中,我们通过 output.filenameoutput.path 属性,来告诉 webpack bundle 的名称,以及我们想要 bundle 生成(emit)到哪里。可能你想要了解在代码最上面导入的 path 模块是什么,它是一个 Node.js 核心模块,用于操作文件路径。

如果你定义的入口文件有多个,那么我们需要使用占位符来确保输出文件的唯一性

output: {
        filename: '[name].js',
        path: __dirname + '/dist'
    }

如今这么少的配置,就能够让你运行一个服务器并在本地使用命令npm start或者npm run build来打包我们的代码进行发布

Loader

loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)。loader 可以将所有类型的文件转换为 webpack 能够处理的有效模块,然后你就可以利用 webpack 的打包能力,对它们进行处理。

var path = require('path')

var baseConfig = {
    entry: {
        main: './src/index.js'
    },
    output: {
        filename: 'main.js',
        path: path.resolve(__dirname, 'dist')
    },
    module: {
        rules: [
          { 
              test: /\.txt$/,
              use: 'raw-loader' 
          }
        ]
    }
}

module.exports = baseConfig

以上配置中,对一个单独的 module 对象定义了 rules 属性,里面包含两个必须属性:test 和 use。

还有 loader 的一些其他配置

    test: 匹配所处理文件的扩展名的正则表达式(必须)
    loader: loader的名称(必须)
    include/exclude: 手动添加处理的文件 / 屏蔽不需要处理的文件(可选)
    query: 为loaders提供额外的设置选项
    
        var baseConfig = {
            // ...
            module: {
                rules: [
                    {
                        test: /*匹配文件后缀名的正则*/,
                        use: [
                            loader: /*loader名字*/,
                            query: /*额外配置*/
                        ],
                        exclude: /node_modules/
                    }
                ]
            }
        }

列举一些常用的 loader

Plugin

loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量。

想要使用一个插件,你只需要 require() 它,然后把它添加到 plugins 数组中。多数插件可以通过选项(option)自定义。你也可以在一个配置文件中因为不同目的而多次使用同一个插件,这时需要通过使用 new 操作符来创建它的一个实例。

const HtmlWebpackPlugin = require('html-webpack-plugin'); // 通过 npm 安装
const webpack = require('webpack'); // 用于访问内置插件

const config = {
  module: {
    rules: [
      { test: /\.txt$/, use: 'raw-loader' }
    ]
  },
  plugins: [
    new HtmlWebpackPlugin({template: './src/index.html'})
    // 依据一个简单的index.html模版,生成一个自动引用你打包后的js文件的新index.html
  ]
};

module.exports = config;

参考

Webpack官方文档
前端面试之webpack篇

上一篇下一篇

猜你喜欢

热点阅读