webpack--前端高频面试题

82 阅读2分钟

webpack总结(面试题)

  • 1.什么是webpack

    • 静态模块打包工具
  • 2.webpack作用

    • 分析、压缩、打包代码
  • 3.webpack好处

    • 减少文件体积、减少文件数量
    • 提高网页加载速度
  • 4.webpack工作流程

    • 1.初始化参数:从配置文件读取与合并参数,得出最终的参数
    • 2.开始编译:用上一步得到的参数初始化 Compiler 对象,加载所有配置的插件,开始执行编译
    • 3.确定入口:根据配置中的 entry 找出所有的入口文件
    • 4.编译模块:从入口文件出发,调用所有配置的 Loader 对模块进行翻译,再找出该模块依赖的模块,再递归本步骤直到所有入口依赖的文件都经过了本步骤的处理
    • 5.完成模块编译:在经过第4步使用 Loader 翻译完所有模块后,得到了每个模块被翻译后的最终内容以及它们之间的依赖关系
    • 6.输出资源:根据入口和模块之间的依赖关系,组装成一个个包含多个模块的 Chunk,再把每个 Chunk 转换成一个单独的文件加入到输出列表,这步是可以修改输出内容的最后机会
    • 7。输出完成:在确定好输出内容后,根据配置确定输出的路径和文件名,把文件内容写入到文件系统。
  • 5.什么是loader,什么是Plugin

    • loader直译为"加载器"。webpack将一切文件视为模块,但是webpack原生是只能解析js和JSON文件,如果想将其他文件也打包的话,就会用到loader。 所以loader的作用是让webpack拥有了加载和解析非JavaScript文件的能力。

      • 说人话: loader就是用于解析文件的

        • 例如:css-loader 、style-loader、image-loader
    • Plugin直译为"插件"。Plugin可以扩展webpack的功能,让webpack具有更多的灵活性。 在 webpack 运行的生命周期中会广播出许多事件,Plugin 可以监听这些事件,在合适的时机通过 webpack 提供的 API 改变输出结果。

      • 说人话:插件就是拓展功能的

        • 例如:html-webpack-plugin