你需要知道的webpack高频面试题

本文主要探讨了webpack的模块打包原理、基本功能、与gulp、grunt的区别,详细解释了entry和output、loader与plugins的作用。此外,还介绍了webpack在单页和多页应用的配置、模块热更新、长缓存优化以及Tree-shaking的概念。同时,提到了在实际项目中使用过的webpack插件和loader,例如babel-loader、html-webpack-plugin等。
摘要由CSDN通过智能技术生成

谈谈你对webpack的看法

webpack是一个模块打包工具,可以使用它管理项目中的模块依赖,并编译输出模块所需的静态文件。它可以很好地管理、打包开发中所用到的HTML,CSS,JavaScript和静态文件(图片,字体)等,让开发更高效。对于不同类型的依赖,webpack有对应的模块加载器,而且会分析模块间的依赖关系,最后合并生成优化的静态资源。

webpack的基本功能和工作原理?

  • 代码转换:TypeScript 编译成 JavaScript、SCSS 编译成 CSS 等等
  • 文件优化:压缩 JavaScript、CSS、HTML 代码,压缩合并图片等
  • 代码分割:提取多个页面的公共代码、提取首屏不需要执行部分的代码让其异步加载
  • 模块合并:在采用模块化的项目有很多模块和文件,需要构建功能把模块分类合并成一个文件
  • 自动刷新:监听本地源代码的变化,自动构建,刷新浏览器
  • 代码校验:在代码被提交到仓库前需要检测代码是否符合规范,以及单元测试是否通过
  • 自动发布:更新完代码后,自动构建出线上发布代码并传输给发布系统。

webpack构建过程

  • 从entry里配置的module开始递归解析entry依赖的所有module
  • 每找到一个module,就会根据配置的loader去找对应的转换规则
  • 对module进行转换后,再解析出当前module依赖的module
  • 这些模块会以entry为单位分组,一个entry和其所有依赖的module被分到一个组Chunk
  • 最后webpack会把所有Chunk转换成文件输出
  • 在整个流程中webpack会在恰当的时机执行plugin里定义的逻辑

webpack打包原理

将所有依赖打包成一个bundle.js,通过代码分割成单元片段按需加载

什么是webpack,与gulp,grunt有什么区别

  • webpack是一个模块打包工具,可以递归地打包项目中的所有模块,最终生成几个打包后的文件。
  • 区别:webpack支持代码分割,模块化(AMD,CommonJ,ES2015),全局分析

什么是entry,output?

  • entry 入口,告诉webpack要使用哪个模块作为构建项目的起点,默认为./src/index.js
  • output 出口,告诉webpack在哪里输出它打包好的代码以及如何命名,默认为./dist

什么是loader,plugins?

  • loader是用来告诉webpack如何转换某一类型的文件,并且引入到打包出的文件中。
  • plugins(插件)作用更大,可以打包优化,资源管理和注入环境变量

什么是bundle,chunk,module?

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

如何自动生成webpack配置?

可以用一些官方脚手架

  • webpack-cli
  • vue-cli
// 首先安装
npm install -g @vue/cli
// 新建项目hello
vue create hello
  • nuxt-cli
// 确保安装了npx,npx在npm5.2.0默认安装了
// 新建项目hello
npx create-nuxt-app hello
参考webpack视频讲解:进入学习

webpack如何配置单页面和多页面的应用程序?

  • 单个页面
module.exports = {
   
    entry: './path/to/my/entry/file.js'
}
  • 多页面应用程序
module.entrys = {
   
    entry: {
   
        pageOne: './src/pageOne/index.js',
        pageTwo: './src/pageTwo/index.js'
    }
}

webpack-dev-server和http服务器如nginx有什么区别?

webpack-dev-server使用内存来存储webpack开发环境下的打包文件,并且可以使用模块热更新,相比传统http服务器开发更加简单高效,

什么是模块热更新?

webpack的一个功能,可以使代码修改后不用刷新浏览器就自动更新,高级版的自动刷新浏览器

dev-server是怎么跑起来的

webpack-dev-server支持两种模式来自动刷新页面

  • iframe模式(页面放在iframe中,当发送改变时重载)
    无需额外配置,只要以这种格式url访问即可。http://localhost:8080/webpack-dev-server/index.html
  • inline模式(将webpack-dev-server的客户端入口添加到bundle中)
    inline模式下url不用发生变化,但启动inline模式分两种情况
// 以命令行启动webpack-dev-server有两种方式// 方式1 在命令行中添加--inline命令// 方式2 在webpack-config.js添加devServer:{
   inline: true
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
webpack和gulp是两个常用的构建工具,用于优化和打包前端资源。它们在一些方面有着不同的特点。 Webpack是一个现代化的模块打包工具,它将所有文件都视为模块,并通过加载器(loader)来解析和转换这些文件。webpack的主要目标是将多个模块打包成一个或多个文件,以便在浏览器中使用。它具有强大的模块化支持和灵活的配置选项,可以处理各种类型的文件,如JavaScript、CSS、图片等。同时,webpack内置了一些功能,如代码分割、懒加载等,使得开发者可以更好地优化和管理前端资源。 Gulp是一个基于任务的构建工具,它使用流(stream)来处理前端资源。gulp通过编写任务(task)来定义源文件的处理过程,并将处理结果输出到指定目录。它可以进行文件的合并、压缩、重命名等操作,并且可以自定义任务的执行顺序。相对于webpack,gulp更加灵活,可以处理更多种类的任务,如自动化测试、文件的复制和移动等。但是,gulp相对于webpack来说,对于模块化的支持相对较弱,需要借助其他插件来实现。 综上所述,webpack和gulp在功能和使用方式上有所不同。webpack更适用于模块化的项目,可以更好地处理复杂的依赖关系和模块管理;而gulp更适合处理一些简单的任务和流程,具有更大的灵活性。在面试中,常常会涉及到webpack和gulp的使用和配置,以及它们之间的区别和优劣势。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [webpack-interview-questions:可用于准备面试或测试知识的Webpack问题答案](https://download.csdn.net/download/weixin_42121754/15101046)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [webpack 常见面试题](https://blog.csdn.net/write_bug_job/article/details/124355413)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [面试官常问 webpack 面试题](https://blog.csdn.net/weixin_59519449/article/details/123983352)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值