webpack学习笔记

webpack是什么?

webpack简单来说是一个模块打包机:分析你的项目结构,找到JavaScript模块、图片以及其它的一些浏览器不能直接运行的拓展语(Scss,TypeScript等,并将其打包为合适的格式以供浏览器使用。

webpack打包.png

为什么我们要使用webpack?

随着前端开发项目功能越来越丰富的需求,前端所写的JavaScript也越来越复杂还有得安装一大堆依赖,给我们前端开发带来越来越多的复杂度,所以在这个时候webpack就可以帮助我们将开发复杂度化简提高开发效率,同时他还具备以下优点
① 模块化开发(import,require),让我们可以把复杂的程序细化为小的文件;
② 预处理(Less,Sass,ES6,TypeScript……)
③ 主流框架脚手架支持(Vue,React,Angular)

安装webpack

安装webpack之前我们得先提前安装好node.js,因为我们得需要通过使用npm安装webpack

npm install webpack -g   (这是全局安装)
npm install webpack --save-dev  (这是安装到自己本地的项目)
或者下面这种带有版本号的安装
npm install --save-dev webpack@<version>

(这里提示最好是安装到本地项目里面,因为当你同时开着多个项目的时候可能会出现不同项目需要不同版本的webpack)

-如果你使用 webpack 4+ 版本,你还需要安装 CLI

npm install --save-dev webpack-cli

设置webpack-dev-server

在开发时,每次更改文件后要运行npm run build 来重新编译、打包文件,无聊又麻烦。我们可以设置 webpack-dev-server来让他自动运行。webpack-dev-server 主要是启动了一个使用 express 的 Http服务器 ,它的作用主要是用来伺服资源文件 。此外这个 Http服务器 和 client 使用了 websocket 通讯协议,原始文件作出改动后, webpack-dev-server 会实时的编译,但是最后的编译的文件并没有输出到目标文件夹。在webpack.config.js配置文件中增加入口命令可以使文件变化时浏览器自动刷新。
首先要安装它 npm install webpack-dev-server --save-dev。然后在package.json文件的scripts部分增加快捷指令:

"scripts": {
    "dev": "webpack-dev-server --open --history-api-fallback",
    "build": "webpack"
  },

webpack的使用

entry与output

//基本结构
module.exports = {
var path = require('path');
  context: path.join(__dirname),  //这是entry配置项的根目录(绝对路径)
    entry: "./src/root.js",//打包入口文件,就是打包谁
    output: {
        path: __dirname + "/dist/",//打包后文件放置的目录路径
        // publicPath: "发布项目时在相对路径前面添加的绝对路径"
        filename: "bundle.js"//打包后文件的名字
    }
}

entry:

写法一:字符串 ----------打包一个入口文件,如上

写法二: 数组 ------------['./a.js', './b.js'] 打包两个不相依赖的文件,打包在一起

写法三:对象----------在多页面应用中,针对不同的页面填写不同的入口文件

entry: {
    page1:  './a.js',-----可以是一个
    page2: ['./as.js', './b.js']-------可以是多个
}

此时如果还像上面那样子写output则只会生成一个输出文件,且后面的打包文件会把前面输出文件覆盖,解决方法是在filename中添加一个占位符,区分不同输出文件,方法有三种:
1 [name] 就是entry对象的key值,page1, page2
output: {
filename: '[name]'.js,
path: __dirname + 'src'
}
2 [hash] 每次打包生成的一个hash值,假设为“123asd”,可以和[name]一起使用
output: {
filename: '[name]-[hash]'.js,
path: __dirname + 'src'
}
多个打包生成文件hash相同,都是“123asd”

loader

module.exports = {

    module: {
        rules: [
            {//js、jsx
19                 test: /\.jsx?$/,
20                 exclude:/node_modules/,//排除node_modules中的库文件,加快编译速度
21                 loader: 'babel',
22                 query:{
23                     presets:['es2015', 'react']
24                 }
25             },            
26             {//css
27                 test: /\.css$/,
28                 loader: ExtractTextPlugin.extract("style", "css")//多个加载器通过!链接,可忽略加载器后缀“-loader”
29             },            
30             {//sass,还需要安装node-sass
31                 test: /\.scss$/,
32                 loader: 'style!css!sass'
33             },
34             
35             {//less,还需要安装less
36                 test: /\.less$/,
37                 loader: 'style!css!less'
38             },
39             {//url-loader:图片、字体图标加载器,是对file-loader的上层封装,支持base64编码。传入的size(也有的写limit) 参数是告诉它图片如果不大于 25KB 的话要自动在它从属的 css 文件中转成 BASE64 字符串.
40                 test: /\.(png|jpg|jpeg|gif|svg|woff|woff2|ttf|eot)$/,
41                 loader: 'url?limit=25000&name=[name].[ext]'
42             }
        ]
    },
}

webpack 本身只能处理 JavaScript 模块,如果要处理其他类型的文件,就需要使用 loader 进行转换。Loader 可以理解为模块和资源的转换器,它本身是一个函数,接受源文件作为参数,返回转换的结果。这样,我们就可以通过 require 来加载任何类型的模块或文件,比如 CoffeeScript、 JSX、 LESS 或图片。Loader 本身也是运行在 node.js 环境中的 JavaScript 模块,它通常会返回一个函数。大多数情况下,我们通过 npm 来管理 loader,但是你也可以在项目中自己写 loader 模块。

一般loader 一般以xxx-loader的方式命名,xxx代表了这个 loader 要做的转换功能,比如css-loader。Loader 可以在require()引用模块的时候添加,也可以在 webpack 全局配置中进行绑定,还可以通过命令行的方式使用。例如页面中要引入样式文件main.css,我们可以将main.css看成一个模块,然后css-loader会遍历 CSS 文件,然后找到 url() 处理他们,style-loader 会把原来的 CSS 代码插入页面中的一个 style 标签中。

插件plugins

插件可以完成更多loader不能完成的任务。在webpack.config.js中增加config.plugins:
列如webpack插件 html-webpack-plugin,就是可以帮你在打包的时候自动给你生成index.html并且帮你往里面引入你的js文件,你就省的自己去手动引入创建了

 1 var webpack = require("webpack");
 2 var path = require('path');
 3 var ExtractTextPlugin = require('extract-text-webpack-plugin');
 4 var HtmlWebpackPlugin = require('html-webpack-plugin');
 5 
 6 var config = {
 7         //省略entry、output等
 8      plugins:[//给打包输出的文件加banner
 9         new webpack.BannerPlugin("The file is creted by yangmin.--" + new Date()),
10         new webpack.ProvidePlugin({
11           $: "webpack-zepto",             
12       }),
13       /*插件:单独使用style标签加载css文件*/
14       new ExtractTextPlugin("css/[name].css"),//设置其路径(路径相对于path)
15       /*插件:动态生成html,在webpack完成前端资源打包以后,自动将打包后的资源路径和版本号写入HTML中,达到自动化的效果。*/
16       new HtmlWebpackPlugin({
17           filename:'view/index-build.html',    //生成的html存放路径,相对于 path
18             template:'src/view/index.html',    //html模板路径
19             inject:true,    //允许插件修改哪些内容,包括head与body
20             hash:false,    //为静态资源生成hash值
21             minify:{    //压缩HTML文件
22                 removeComments:false,    //移除HTML中的注释
23                 collapseWhitespace:false    //删除空白符与换行符
24            }
25        })
26     ]
27 };
28    module.export = config;   

babel的实现

安装 npm i -D @babel-preset-env @babel-core babel-loader

@babel-preset-env:可以让我们灵活设置代码目标执行环境
@babel-core: babel核心库
babel-loader: webpack的babel插件,让我们可以在webpack中运行babel

配置.babelrc

{
    "presets": ['@babel/preset-env']
}

配置webpack.config.js

module.exports = {
    entry: './src/index.js',
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: 'bundle.js'
    },
    module: {
        rules: [{
            test: /\.js$/,
            exclude: /node_modules/,
            use: {loader: 'babel-loader'}
        }]
    }
}

在webpack中如何做到长缓存优化?

webpack中可以在output中指定chunkhash,并且分离经常更新的代码和框架代码。通过NameModulesPlugin或HashedModuleIdsPlugin使再次打包文件名不变。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成...
    EarthChen阅读 394评论 0 1
  • 全局安装webpack 全局安装webpack会有个问题,就是当你有两个项目依赖于不同版本的webpack,就会有...
    説好的妹紙呢阅读 1,814评论 0 11
  • webpack第一次出现在我的视线,是在一次面试中,当时面试官问我是否了解AMD、CMD、Gulp、webpack...
    云飘雾散阅读 1,768评论 0 1
  • 学习目的 学习前端构建化工具 webpack,能熟练掌握 并使用 webpack 对项目进行打包优化。 ...
    _1633_阅读 1,351评论 0 7
  • 我们成长的这些年 是岁月写给父母的散文诗 内容是我们的成长 终章是他们的老去 #写给父母的散文诗# SQ
    取个能看的名字阅读 613评论 0 0