一只很酷的蘑菇

webpack学习笔记

阅读量:

webpack学习笔记

官方文档

webpack的特点

代码拆分

Webpack 有两种组织模块依赖的方式,同步和异步。异步依赖作为分割点,形成一个新的块。在优化了依赖树后,每一个异步区块都作为一个文件被打包。

Loader

Webpack 本身只能处理原生的 JavaScript 模块,但是 loader 转换器可以将各种类型的资源转换成 JavaScript 模块。这样,任何资源都可以成为 Webpack 可以处理的模块。

智能解析

Webpack 有一个智能解析器,几乎可以处理任何第三方库,无论它们的模块形式是 CommonJSAMD 还是普通的 JS 文件。甚至在加载依赖的时候,允许使用动态表达式 require("./templates/" + name + ".jade")

插件系统

Webpack 还有一个功能丰富的插件系统。大多数内容功能都是基于这个插件系统运行的,还可以开发和使用开源的 Webpack 插件,来满足各式各样的需求。

快速运行

Webpack 使用异步 I/O 和多级缓存提高运行效率,这使得 Webpack 能够以令人难以置信的速度快速增量编译。

配置:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
const path = require('path');
const htmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
//入口文件
// entry: './src/script/main.js',
// entry:["./src/script/main.js","./src/script/a.js"],//把2个文件打包在一起
entry:{
main:'./src/script/main.js',
a:"./src/script/a.js"
},
//输出
output: {
path: path.resolve(__dirname, './dist'),
filename: 'js/[name]-[chunkhash].js',
publicPath: 'http://cdn.com' //编译的文件域名
},
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
}
]
},
//source-map 仅开发环境使用
devtool: 'inline-source-map',
plugins:[
//https://www.npmjs.com/package/html-webpack-plugin
new htmlWebpackPlugin({
filename:'index.html',
template: 'index.html',
inject:'body', //script标签放的位置
title:'webpack is index',
minify: {
removeComments:true,//删除注释
collapseWhitespace:true
},
// chunks: ['main','a'] //指定当前html包含的chunk
excludeChunks:['a']//指定排除的chunk
}),
new htmlWebpackPlugin({
filename:'a.html',
template: 'index.html',
inject:'body', //script标签放的位置
title:'webpack is a',
minify: {
removeComments:true,//删除注释
collapseWhitespace:true
},
// chunks: ['a'] //指定当前html包含的chunk
excludeChunks:['main']//指定排除的chunk
}),
]
};

陈柯伊

梦想一克拉 热血一卡车 眼泪一酒瓶 熬夜一光年

评论

文章目录