webpack

作者: 糖糖不加糖_ | 来源:发表于2023-03-01 19:45 被阅读0次

是什么

webpack是打包工具,可以将多个模块打包成一个或多个包,以便在浏览器中使用

作用

主要作用是管理模块依赖关系,优化文件体积和加载速度,提供各种优化和拓展功能

工作原理

  • 【加载】解析配置文件,加载需要打包的模块和插件
  • 【解析】从入口文件开始,根据模块间的依赖关系,递归解析所有需要打包的模块
  • 【处理】根据配置文件中的规则,对模块进行Loader处理和代码分离
  • 【打包】将处理后的模块打包成一个或多个包(bundle)
  • 【优化】对打包后的包进行优化,如压缩,缓存
  • 【输出】输出打包结果,供浏览器使用

什么是Loader,怎么配置Loader

用于处理各种类型的文件,将其转换成模块,并放到打包结果中。
常见的有babel-loader、css-loader、sass-loader等
配置loader是在webpack.config.js中添加一个module.rules数组,每个对象表示一条规则,包含test、use、exclude属性 eg:

module.exports = {
 // ...
 module: {
   rules: [
     {
       test: /\.css$/,
       use: ["style-loader", "css-loader"],
     },
   ],
 },
};

什么是Plugin,怎么编写Plugin

Plugin是webpack的一个拓展机制,用于拓展和优化webpack的功能。
常见的有:HtmlWebpackPlugin(生成html文件)、CleanWebpackPlugin(清除目录文件夹)等

// 使用方式
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

module.exports = {
  // ...其他配置
  plugins: [
    new CleanWebpackPlugin(),
    // ...其他插件
  ]
};

编写Plugin是创建一个js类,并实现apply方法,apply方法里接收一个compiler(编译器)对象,用于注册各种钩子函数

class MyPlugin {
  apply(compiler) {
  compiler.hooks.emit.tap("MyPlugin", (compilation) => {
    console.log("Webpack is emitting files...");
});

如何使用 Webpack 实现代码分离和按需加载?

代码分离和按需加载能有效减少,打包结果的体积和加载时间

代码分离:可以将一个大包拆分成多个小包

  • 使用entry配置多个入口文件,然后每个入口文件生成一个包
  • 使用optimization.spliteChunks配置公共代码的抽取规则,将公共代码抽取到一个单独的包里

按需加载:可以根据需要动态加载模块,避免一次性加载所有代码

  • 使用import、require.ensure()

Webpack 的缓存机制是什么?如何使用缓存?

缓存机制:根据文件内容的hash值,生成一个唯一的缓存标识,如果模块内容没有改变,就是用缓存中的打包结果
使用缓存:webpack.config.js中设置cache: true

Tree Shaking是什么,怎么使用

用于去除未使用的代码,减少打包体积,原理是通过静态分析代码中的依赖关系,只保留被使用部分
使用:在webpack.config.js中配置optimization.usedExports和optimization.sideEffects

module.exports = {
  // ...
  optimization: {
    usedExports: true,
    sideEffects: false,
  },
};

相关文章

网友评论

      本文标题:webpack

      本文链接:https://www.haomeiwen.com/subject/niorldtx.html