前端面试题webpack(2)

8. Loader和Plugin的不同

• loader 加载器
Webpack 将一切文件视为模块,但是 webpack 原生是只能解析 js 文件. Loader 的作用是让 webpack 拥有了加载和解析非 JavaScript 文件的能力
在 module.rules 中配置,也就是说他作为模块的解析规则而存在,类型为数组
• Plugin 插件
扩展 webpack 的功能,让 webpack 具有更多的灵活性
在 plugins 中单独配置。类型为数组,每一项是一个 plugin 的实例,参数都通过构造函数传入

9. webpack的构建流程是什么

  1. 初始化参数:从配置文件和 Shell 语句中读取与合并参数,得出最终的参数
  2. 开始编译:用上一步得到的参数初始化 Compiler 对象,加载所有配置的插件,执行对象的 run 方法开始执行编译
  3. 确定入口:根据配置中的 entry 找出所有的入口文件
  4. 编译模块:从入口文件出发,调用所有配置的 Loader 对模块进行翻译,再找出该模块依赖的模块,再递归本步骤直到所有入口依赖的文件都经过了本步骤的处理
  5. 完成模块编译:在经过第4步使用 Loader 翻译完所有模块后,得到了每个模块被翻译后的最终内容以及它们之间的依赖关系
  6. 输出资源:根据入口和模块之间的依赖关系,组装成一个个包含多个模块的 Chunk,再把每个 Chunk 转换成一个单独的文件加入到输出列表,这步是可以修改输出内容的最后机会
  7. 输出完成:在确定好输出内容后,根据配置确定输出的路径和文件名,把文件内容写入到文件系统
    在以上过程中,Webpack 会在特定的时间点广播出特定的事件,插件在监听到感兴趣的事件后会执行特定的逻辑,并且插件可以调用 Webpack 提供的 API 改变 Webpack 的运行结果

10. 是否写过Loader和Plugin?描述一下编写loader或plugin的思路

编写 Loader 时要遵循单一原则,每个 Loader 只做一种"转义"工作。 每个 Loader 的拿到的是源文件内容(source),可以通过返回值的方式将处理后的内容输出,也可以调用 this.callback() 方法,将内容返回给 webpack 。 还可以通过 this.async() 生成一个 callback 函数,再用这个 `callback`` 将处理后的内容输出出去
相对于 Loader 而言,Plugin 的编写就灵活了许多。 webpack 在运行的生命周期中会广播出许多事件,Plugin 可以监听这些事件,在合适的时机通过 Webpack 提供的 API 改变输出结果

11. webpack的热更新是如何做到的?说明其原理

具体可以参考 这里

12. 如何利用webpack来优化前端性能

• 压缩代码。删除多余的代码、注释、简化代码的写法等等方式
• 利用 CDN 加速。在构建过程中,将引用的静态资源路径修改为 CDN 上对应的路径
• 删除死代码 Tree Shaking)。将代码中永远不会走到的片段删除掉
• 优化图片,对于小图可以使用 base64 的方式写入文件中
• 按照路由拆分代码,实现按需加载,提取公共代码
• 给打包出来的文件名添加哈希,实现浏览器缓存文件

13. 如何提高webpack的构建速度

参考 这里

14. 怎么配置单页应用?怎么配置多页应用

• 单页应用可以理解为 webpack 的标准模式,直接在 entry 中指定单页应用的入口即可
• 多页应用的话,可以使用 webpack 的 AutoWebPlugin 来完成简单自动化的构建,但是前提是项目的目录结构必须遵守他预设的规范

15. 什么是bundle,什么是chunk,什么是module

bundle 是由 webpack 打包出来的文件,chunk 是指 webpack 在进行模块的依赖分析的时候,代码分割出来的代码块。module是开发中的单个模块

你可能感兴趣的:(面试题)