随着前端的不断发展,现代前端开发的复杂度和规模越来越庞大。工程化的思想催生了很多流行框架的进程,作为现在最流行的前端构建工具–webpack,很多面试、工作场景中都会出现了它的身影。所以对于现在的前端来说,了解并能够使用webpack,无论对个人技能或者职场求职来说,都是一种有力的提升。
小编创建了一个群,有前端系统的学习资料和帮助解答问题,欢迎各位小白和大牛们的加入,点击:加群
1:对webpack的了解
本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module
bundler),将项目当作一个整体,通过一个给定的的主文件,webpack将从这个文件开始找到你的项目的所有依赖文件,使用loaders处理它们,最后打包成一个或多个浏览器可识别的js文件。
核心概念:
module.exports = {
entry: './path/to/my/entry/file.js'
};
输出(output)
output 属性告诉 webpack 在哪里输出它所创建的 bundles ,以及如何命名这些文件,默认值为 ./dist
loader
loader 让 webpack 能够去处理那些非 JavaScript 文件(webpack 自身只理解 JavaScript)
插件(plugins)
loader 被用于转换某些类型的模块,而插件则可以用于执行范围更广的任务。插件的范围包括,从打包优化和压缩,一直到重新定义环境中的变量
模式
通过选择 development 或 production 之中的一个,来设置 mode 参数,你可以启用相应模式下的 webpack 内置的优化
module.exports = {
mode: 'production'
};
2. webpack,里面的webpack.config.js怎么配置
test:/\.css$/, //支持正则
loader:'style-loader!css-loader'
}
]
},
//配置服务
devServer:{
hot:true, //启用热模块替换
inline:true
//此模式支持热模块替换:热模块替换的好处是只替换更新的部分,而不是页面重载.
},
//其他解决方案配置
resolve:{
extensions:['','.js','.json','.css','.scss']
},
//插件
plugins:[
new webpack.BannerPlugin('This file is create by baibai')
]
}
3. webpack本地开发怎么解决跨域的
// webpack.config.js
var WebpackDevServer = require("webpack-dev-server");
module.exports = {
...
devServer: {
...
port: '8088', //设置端口号
// 代理设置
proxy: {
'/api': {
target: 'http://localhost:80/index.php', // 目标代理
pathRewrite: {'^/api' : ''}, // 重写路径
secure: false, // 是否接受运行在 HTTPS 上
}
}
}
}
4. 如何配置多入口文件
配置多个入口文件
entry: {
home: resolve(__dirname, "src/home/index.js"),
about: resolve(__dirname, "src/about/index.js")
}
5. webpack与grunt、gulp的不同
三者都是前端构建工具 grunt 和 gulp 是基于任务和流的。找到一个(或一类)文件,对其做一系列链式操作,更新流上的数据,
整条链式操作构成了一个任务,多个任务就构成了整个web的构建流程webpack 是基于入口的。webpack 会自动地递归解析入口所需要加载的所有资源文件,然后用不同的 Loader 来处理不同的文件,用
Plugin 来扩展 webpack 功能webpack 与前者最大的不同就是支持代码分割,模块化(AMD,CommonJ,ES2015),全局分析。
6. 有哪些常见的Loader?他们是解决什么问题的
我
7. 有哪些常见的Plugin?他们是解决什么问题的
8. Loader和Plugin的不同
Webpack 将一切文件视为模块,但是 webpack 原生是只能解析 js 文件. Loader 的作用是让 webpack
拥有了加载和解析非 JavaScript 文件的能力 在 module.rules 中配置,也就是说他作为模块的解析规则而存在,类型为数组
扩展 webpack 的功能,让 webpack 具有更多的灵活性 在 plugins 中单独配置。类型为数组,每一项是一个 plugin的实例,参数都通过构造函数传入
9. webpack的构建流程是什么
在以上过程中,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:怎么配置单页应用?怎么配置多页应用
13: 什么是bundle,什么是chunk,什么是module
bundle 是由 webpack 打包出来的文件,chunk 是指 webpack
在进行模块的依赖分析的时候,代码分割出来的代码块。module是开发中的单个模块。
小编创建了一个群,有前端系统的学习资料和帮助解答问题,欢迎各位小白和大牛们的加入,点击:加群