weabpck的基础应用
https://blog.zhangjd.me/2016/06/19/webpack-your-bags/
https://juejin.im/post/5cc26dfef265da037b611738#heading-9
wbepck插件实现
https://www.cnblogs.com/MuYunyun/p/8875908.html
https://juejin.im/post/5ba34e54e51d450e5162789b#heading-56
总结
核心概念:
webpack的模块打包工具,通过分析模块的依赖,最终将所有的模块打包成一份,或者多份的(bundder)
提供html引用,webpack仅仅提供了打包功能和一套文件处理机制,通过plugin和loader对代码进行预编译和打包
entry:webpck项目的入口文件,开始编译、打包
output:webpack的输出文件的路径
module:模块,webpack的任何的一个文件都可以作为一个模块,对于文件进行加载解析
loader:模块加载器
plugin:拓展插件,plugin 可以通过webpack有相应的事件钩子,介入到打包过程中的任意环节
loader
由于loader只能识别js,对于css/img/html等类型的文件无法加载,因此就需要不同类型文件进行转化,
原理
通过babylon 将es6/7转换成AST树
通过bable-traverse 对ast 进行遍历转译,生成新的AST树
新的AST树,通过generator的方式解析成为es6
1)babylon:babel里面用来将js代码词法分析,生成ast,他的结构有些像acron,它的返回的结构里面包含着ast和tokens。
require("babylon").parse("code", {
// parse in strict mode and allow module declarations
sourceType: "module",
plugins: [
// enable jsx and flow syntax
"jsx",
"flow"
]
});
sourceType: module表示的是在严格模式下解析并且允许模块定义(即能识别import和expor语法);script识别不了。
2)babel-traverse:功能就像estraverse一样,主要是给plugin提供遍历ast节点的功能;
var babylon = require('babylon');
var result = babylon.parse(code, { sourceType: "module",});
console.log('result:', result);
import traverse from "babel-traverse";
traverse(result, {
enter(node) {
console.log(node);
}
});
3)babel-generator:将ast生成js代码;
var babylon = require('babylon');
var result = babylon.parse(code, { sourceType: "module",});
console.log('result:', result);
import traverse from "babel-traverse";
import generate from 'babel-generator';
traverse(result, {
enter(node) {
console.log(node);
}
});
var conde1 = generate(result);
console.log('generate:', conde1);
loader还有一些特性
1,按照链式相反方向执行
2,loader可以同步也可以异步:例如( style-loader 是同步的(看源码就知道,直接 return);而 less-loader 却是异步的,)
3,基于node环境,拥有较高的权限,可以对文件进行增删查改的操作
有哪些loader
1,file-oder:加载文件资源,比如字体、图片等,具有移动/命名/复制等功能
2,url-loader:通常加载小图片,可以设置limit,如果小于一个值,就转换成base64,减少http请求
3,style-loader:将style代码以css标签插入到代码中
4,sass/less-loader:css的预处理器,在css中增加了很多新的语法,来增强开发效率
5,css-loader:分析@import和url(),引入css文件与对应的资源
6,babel-loader:加载js/jsx文件,将es6/es7转换成es5,
7,ts-loader:加载ts/tsx文件,编译typeSCRIPT
8,postcss-loader:用于css兼容处理,具有众多的功能,例如,添加前缀,单位转换等
plugin
Webpack 会触发许多事件钩子,Plugin 可以监听这些事件,根据需求在相应的时间点对打包内容进行定向的修改。
class Plugin{
// 注册插件时,会调用 apply 方法
// apply 方法接收 compiler 对象
// 通过 compiler 上提供的 Api,可以对事件进行监听,执行相应的操作
apply(compiler){
// compilation 是监听每次编译循环
// 每次文件变化,都会生成新的 compilation 对象并触发该事件
compiler.plugin('compilation',function(compilation) {})
}
}
注册插件:
// webpack.config.js
module.export = {
plugins:[
new Plugin(options),
]
}
Compiler 全局唯一,且从启动生存到结束,它包含了当前 Webpack 中的所有配置信息,如 options, loaders, plugins 等信息,
Compilation 对应每次编译,每轮编译循环均会重新创建,它包含了当前的输入资源,输出资源,变化的文件等,同时通过它提供的 api,可以监听每次编译过程中触发
的事件钩子;
常用 Plugin:
1,UglifyJsPlugin :压缩、混淆代码
2,CommonsChunkPlugin:代码分割
3,ProvidePlugin:自动加载模块
4,html-webpack-plugin:加载html,并且引入css/js文件
5,extract-text-webpack-plugin/mini-css-extract-plugin ;抽离样式,生成css文件
6,optimize-css-assets-webpack-plugin:css去重
7,webpack-bundle-analyzer:代码分析
8,compression-webpack-plugin:使用gzip压缩js和css
9,happypack:使用多线程,加快代码构建
10,EnvironmentPlugin:定义局部的变量
编译优化:
https://juejin.im/post/5bb8ef58f265da0a972e3434
代码优化
1,消除无用的代码
例如:uglifyJs消除无用代码
2,采用tree-shaking
删除引用但未被使用的代码
但是具有一些副作用(Uglify不做程序流的分析,但是rollup做了)
存在一些副作用
webbpack:不进行babel转义可以进行tree-shaking
但是经过babel编译后,不能够treeShaking
1,Webpack Tree shaking不会清除IIFE(立即调用函数表达式)
2,如果使用第三方的模块,可以尝试直接从文件路径引用的方式使用(这并不是最佳的方式)
import { fn } from 'module';
=>
import fn from 'module/XX';
解决办法:
1,我们可以设定使用loose: true来使得Babel在转化时使用宽松的模式
2, 添加sideEffects标记
//package.json
{
"sideEffects": false,
}
3,对函数外部变量产生影响的行为
3,code-spliting:代码分割
1,按照页面分割:不同页面打包成不同的文件;
2,按照功能进行分割:
将类似于播放器,计算库等大模块进行拆分后再懒加载引入;
提取复用的业务代码,减少冗余代码;
3,按照修改频率进行分割
将第三方库等不常修改的代码单独打包,而且不改变其文件 hash 值,能最大化运用浏览器的缓存;
4,scope hoisting:作用域提升,
将分散的模块划分到同一个作用域中,避免了代码的重复引入,有效减少打包后的代码体积和运行时的内存损耗;
https://segmentfault.com/a/1190000012600832
编译性能的优化
1,升级最新webpack,能有效地提高编译性能
2,使用 dev-server / 模块热替换 (HMR) 提升开发体验;
监听文件变动 忽略 node_modules 目录能有效提高监听时的编译效率;
3, 缩小编译范围:
modules: 指定模块路径,减少递归搜索;
mainFields: 指定入口文件描述字段,减少搜索;
noParse: 避免对非模块化文件的加载;
includes/exclude: 指定搜索范围/排除不必要的搜索范围;
alias: 缓存目录,避免重复寻址;
4,babel-loader:
忽略node_moudles,避免编译第三方库中已经被编译过的代码;
使用cacheDirectory,可以缓存编译结果,避免多次重复编译;
5,多进程并发:
HappyPack: 多进程并发文件的 Loader 解析;
webpack-parallel-uglify-plugin: 可多进程并发压缩 js 文件,提高压缩速度;
6,第三方库模块缓存:
DLLPlugin 和 DLLReferencePlugin 可以提前进行打包并缓存,避免每次都重新编译;
7,使用分析:
Webpack Analyse / webpack-bundle-analyzer 对打包后的文件进行分析,寻找可优化的地方;
配置profile:true,对各个编译阶段耗时进行监控,寻找耗时最多的地方;
- webpack打包理解
webpack打包理解(将所有依赖文件打包到一个文件中) 由于前端代码变得越来越多,越来越复杂, 纯粹脚本化的代码书写方式已经不能满足工程化得需求. 前端模块被抽象出来, 不仅仅包括js模块, 其它如 ...
- webpack - HtmlWebpackPlugin理解
该插件的两个主要作用: 为html文件中引入的外部资源如script.link动态添加每次compile后的hash,防止引用缓存的外部文件问题 可以生成创建html入口文件,比如单页面可以生成一个h ...
- 【webpack】理解配置文件
学习链接: http://blog.csdn.net/hongchh/article/details/55113751 https://segmentfault.com/a/1190000009356 ...
- webpack之理解loader
我们在写webpack配置文件的时候,应该有注意到经常用到loader这个配置项,那么loader是用来做什么的呢? loader其实是用来将源文件经过转化处理之后再输出新文件. 如果是数组形式的话, ...
- webpack基础理解以及使用搭建
1.webpack 是一个前端资源加载/打包工具,前端的常用资源都可以作为一个模板导出,我们在代码中直接引用即可,最后把我们的代码打包整合起来. 前端资源,包括(js,css,图片,模块)等. 下面是 ...
- webpack的理解
webpack是一个模块打包工具,你可以使用webpack管理你的模块依赖,并编译输出模块们所需要的静态文件.它能够很好的管理.打包Web开发中所用到的HTML.Javascript.CSS以及各种静 ...
- [webpack]深入理解proxy代理
1.一个基本的代理 module.exports = { //... devServer: { proxy: { '/api': 'http://localhost:3000' } } }; /api ...
- Webpack的理解以及解决了的问题
一.背景 Webpack 最初的目标是实现前端项目的模块化,旨在更高效地管理和维护项目中的每一个资源 模块化 最早的时候,我们会通过文件划分的形式实现模块化,也就是将每个功能及其相关状态数据各自单独放 ...
- webpack 入门
webpack webpack,是一款模块加载器兼打包工具.能将 JS.coffee.less.sass.图片等作为模块来使用. 经过一个多月的摸索,姑且算是入门了.因此重新写个小DEMO来加深自己对 ...
随机推荐
- simrank python实现
1.数据 pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp.com pc,hp ...
- RMQ Message ACK
原创转载请注明出处:https://www.cnblogs.com/agilestyle/p/11808680.html 消息持久化机制 消息丢失了,需要将队列持久化,即将autoDelete设置成f ...
- C语言的结构体的具体作用是?
在实际问题中,一组数据往往具有不同的数据类型.例如,在学生登记表中,姓名应为字符型:学号可为整型或字符型:年龄应为整型:性别应为字符型:成绩可为整型或实型.显然不能用一个数组来存放这一组数据.因为数组 ...
- oppo面试题
1.synchronized和Lock有什么区别?哪个可重入?哪个效率高? synchronized和Lock都用于线程同步的场景中. synchronized是jdk的关键字,用来构造同步代码块或者 ...
- MySQL跑得慢的原因分析
第一点,硬件太老 硬件我们这里主要从CPU.内存.磁盘三个方面来说下,还有一些因素比如网卡,机房网络等因为文章篇幅关系,就不一一介绍了,以后还有机会可以聊. 首先我们来看下MySQL对CPU的利用特点 ...
- BZOJ 3306: 树 LCT + set 维护子树信息
可以作为 LCT 维护子树信息的模板,写的还是比较优美的. 本地可过,bzoj 时限太紧,一直 TLE #include<bits/stdc++.h> #define setIO(s) f ...
- [CSP-S模拟测试]:chess(搜索+最短路)
题目描述 $pig$在下象棋的时候特别喜欢用马,他总是计算着自己的马还需要几步才能吃掉对方的帅,以及方案数的个数,当然$pig$很笨,所以他只能求助于你.我们假设在$n\times m$的棋盘上,$p ...
- 刷leetcode之路
写的不是很好,仅记录自己所写的,仅供参考. 第七题: Reverse digits of an integer. Example1: x = 123, return 321 Example2: x = ...
- (转)基于TLS证书手动部署kubernetes集群(下)
转:https://www.cnblogs.com/wdliu/p/9152347.html 一.master节点组件部署 承接上篇文章--基于TLS证书手动部署kubernetes集群(上),我们已 ...
- 洛谷P1120 小木棍 [数据加强版](搜索)
洛谷P1120 小木棍 [数据加强版] 搜索+剪枝 [剪枝操作]:若某组拼接不成立,且此时 已拼接的长度为0 或 当前已拼接的长度与刚才枚举的长度之和为最终枚举的答案时,则可直接跳出循环.因为此时继续 ...