webpack面试题
1.webpack的核心概念
Entry:入口,Webpack进行打包的起始点(文件)
Output:出口,webpack编译打包生成的bundle(打包文件)
Loader:模块加载(转换)器,将非js、非json模块包装成webpack能理解的js模块
Plugin:插件,在 Webpack 构建流程中的特定时机插入具有特定功能的代码
Module:模块,在 Webpack眼里一切皆模块,默认只识别js文件, 如果是其它类型文件利用对应的loader转换为js模块
2.webpack配置文件的整体结构
module.exports = {
  entry: '', //入口
  output: {},//输出
  module: {rules: []},//配置loader
  plugins: [] //配置plugin
}
3.webpack模块化打包的基本流程
1. 连接: webpack从入口JS开始, 递归查找出所有相关联的模块, 并【连接】起来形成一个图(网)的结构
2. 编译: 将JS模块中的模块化语法【编译】为浏览器可以直接运行的模块语法(当然其它类型资源也会处理)
3. 合并: 将图中所有编译过的模块【合并】成一个或少量的几个bundle文件, 浏览器真正运行是打包生成的bundle文件
4.比较loader与plugin
1). loader: 用于加载特定类型的资源文件, webpack本身只能打包js。
2). plugin: 用来扩展webpack其它方面的功能, 一般loader处理不了的资源、完成不了的操作交给插件处理。
5.区别live-reload(自动刷新)与hot-realod/HMR(热模替换)
相同点:
    代码修改后都会自动重新编译打包
不同点:
    live-reload: 刷新整体页面, 从而查看到最新代码的效果, 页面状态全部都是新的。
    Hot-reload: 没有刷新整个页面, 只是加载了修改模块的打包文件并运行,
    从而更新页面的局部界面, 整个界面的其它部分的状态还在
6.webpack常用loader与plugin汇总
loader:
    1.【less-loader】:用于将less文件翻译成为css
    2.【css-loader】:用于将css以CommonJs语法打包到js中
    3.【style-loader】:用于动态创建一个style标签,将css引入页面
            备注:上述三个loader一般配合使用,最终实现:翻译less为css,以style标签形式将样式引入页面。
    4.【file-loader】:提取源代码图片资源,到指定位置,可修改文件名等操作。
    5.【url-loader】:与file-loader功能几乎一致,优势是可以对图片进行动态转换base64编码(控制limit属性值可以控制阈值)。
            备注:上述两个loader中url-loader应用比file-loader广泛。
    6.【jshint-loader】:对项目中的js语法进行检查,可选的配置项有:
            emitErrors:true/false
                -- emitErrors为true,检查出的错误显示为 error(错误)类信息。
                -- emitErrors为false,检查出的错误显示为 warning(错误)类信息。
            failOnHint: true/false,
                -- failOnHint为true,当jshint检查出错误时,直接打断当前的代码的编译。
                -- failOnHint为false,当jshint检查出错误时,会继续编译。
            esversion: 6
                --告诉jshint,不再提示新语法兼容性问题(有专门的loader解决新语法问题)
            reporter: function(errors) {}
                --自定义一个报告错误的函数,输出想要的内容
    7.【babel-loader】:将es6语法转换为es5语法
            备注:该loader的使用要借助:babel-loader babel-core babel-preset-es2015
    8.【postcss-loader】:用于扩展css前缀
            备注:
                (1).该loader需要一个postcss.config.js配置文件。
                (2).该loader要配合autoprefixer库使用。
                (3).该loader使用的时机为:["css-loader","postcss-loader","less-loader"]
pulgin:
    1.【extract-text-webpack-plugin】:用于提取项目中的css,最终合并为一个单独的文件。
            备注:上述插件需要配合:css-loader、less-loader两个loader使用,css-loader、less-loader处理之后,交给extract-text-webpack-plugin处理。
    2.【html-webpack-plugin】:自动创建html文件,且自动引入外部资源。配置项如下:
             title:"webpack",
             filename:"index.html",
             template:"./src/index.html"
             //用于压缩html
              minify:{
                     removeComments:true, //移除注释
                     collapseWhitespace:true}//移除换行
    3.【clean-webpack-plugin】:清空webpack的输出目录,防止其他文件“乱入”。
    4.【HotModuleReplacementPlugin】:热模替换(HMR)插件
            备注:1.该模块必须配合webpack-dev-server模块使用,且webpack-dev-server中必须启用HMR
                 2.想要让指定文件支持HMR,必须要:
                        (1).无论是否有插件操作过该类型的资源,最终必须交给loader处理。
                        (2).必须在入口文件中声明使用。
    5.【UglifyJsPlugin】:压缩js的插件,且可以生成sourceMap映射文件,用于方便排查错误。
    6.【less-plugin-clean-css】:压缩css文件,在less-loader翻译less文件之后,该插件介入,开始压缩。webpack面试题的更多相关文章
- 27、前端知识点--webpack面试题(二)
		webpack面试题总结 本文主要是对webpack面试会常被问到的问题做一些总结,且文章会不断持续更新 1.webpack打包原理 把所有依赖打包成一个 bundle.js 文件,通过代码分割成单元 ... 
- webpack面试题(转载)
		1:webpack打包原理 把所有依赖打包成一个bundle.js文件,通过代码分割成单元片段并按需加载. 2:webpack的优势 (1) webpack是以commonJS的形式来书写 ... 
- 前端面试题(webpack)
		(前端面试题大全,持续更新) webpack3升级到4为什么会提升速度? webpack优化有哪些? webpack的css-loader原理讲一下 webpack压缩js css的方法 
- 关于webpack的面试题
		随着现代前端开发的复杂度和规模越来越庞大,已经不能抛开工程化来独立开发了,如react的jsx代码必须编译后才能在浏览器中使用:又如sass和less的代码浏览器也是不支持的. 而如果摒弃了这些开发框 ... 
- 前端面试题整理—Webpack篇
		1.什么是webpack,与grunt和gulp有啥不同 webpack是一个模块打包工具,在webpack里面一切皆模块 通过loader转换文件,通过plugin注入钩子,最后输出有多个模块组合成 ... 
- 前端面试题整理——webpack相关考点
		webpack是开发工具,面试考点重点在配置和使用,原理理解不需要太深. 一.基本配置 1.拆分配置和merge 将公共配置跟dev和prod的配置拆分,然后通过webpack-merge对配置进行整 ... 
- web前端面试试题总结---其他
		其他问题 原来公司工作流程是怎么样的,如何与其他人协作的?如何夸部门合作的? 你遇到过比较难的技术问题是?你是如何解决的? 设计模式 知道什么是singleton, factory, strategy ... 
- javascript 腾讯ABS云平台面试题及面试经历
		既然说到面试前端肯定是Javascript各种问,只好各种答. 面试题肯定离不了,最近热门的Vue.js,React.js,Angular.js,Gulp,Webpack还有各种Js问题,还有令人头痛 ... 
- 前端笔记之ES678&Webpack&Babel(下)AMD|CMD规范&模块&webpack&Promise对象&Generator函数
		一.AMD和CMD规范(了解) 1.1传统的前端开发多个js文件的关系 yuan.js中定义了一个函数 function mianji(r){ return 3.14 * r * r } main.j ... 
随机推荐
- 日志级别facility
			0 EMERG(紧急) 会导致主机系统不可用的情况 1 ALERT(警告) 必须马上采取措施解决的问题 2 CRIT(严重) 比较严重的情况 3 ERR(错误) 运行出现错误 4 WARNING(提醒 ... 
- react使用ant design pro时的滑动图片组件
			react的滑动图片验证,是基于https://segmentfault.com/a/1190000018309458?utm_source=tag-newest做的修改,改动的主要有以下几点: 1. ... 
- Git挽回错误的push(commit)
			若你的(zhu)队友不小心把错误的代码提交到远程仓库,特别是包含了很多删除文件指令,不要尝试使用Git的API修改,或者删除Git仓库里的某次提交记录,风险十分大,正确的做法是备份你的本地源码,然后拉 ... 
- Nacos
			欢迎来到 Nacos 的世界! Nacos 致力于帮助您发现.配置和管理微服务.Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现.服务配置.服务元数据及流量管理. Nacos 帮助您 ... 
- IE与标准浏览器对事件处理的区别?(监听、阻止冒泡、阻止默认等)
			谷歌 IE:监听:addEventListener attachEvent--------要在事件名称前面加on解绑:removeEventListener detachEvent--- ... 
- Java代理(静态代理、JDK动态代理、CGLIB动态代理)
			Java中代理有静态代理和动态代理.静态代理的代理关系在编译时就确定了,而动态代理的代理关系是在运行期确定的.静态代理实现简单,适合于代理类较少且确定的情况,而动态代理则给我们提供了更大的灵活性. J ... 
- ValueError: Graph disconnected: cannot obtain value for tensor Tensor
			一般是Input和下面的变量重名了,导致model里面的input变成了第二次出现的Input变量,而不是最开始模型中作为输入的Input变量 改正方法:给第二个变量赋一个新名字即可 
- git常用指令汇总
			命令行指令 Git 全局设置 git config --global user.name "cqu2003" git config --global user.email &quo ... 
- springboot做api服务时不使用thymeleaf的相关警告DefaultTemplateResolverConfiguration 的消除
			springboot在不配置thymeleaf相关属性的情况下,会提示如下的问题 DefaultTemplateResolverConfiguration - Cannot find template ... 
- elasticsearch 常用命令 一直红色 重启不稳定 不停的宕机
			persistent (重启后设置也会存在) or transient (整个集群重启后会消失的设置). 查看集群状态和每个indices状态.搜索到red的,没用就删除 GET /_cluster/ ... 
