Webpack初步了解(打包,webpack-server)

什么是webpack?

webpack 是前端的一个项目构建工具,它是基于 Node.js 开发出来的一个前端工具;

  1. 使用Gulp, 是基于 task 任务的,适合构建小型项目
  2. 使用Webpack, 是基于整个项目进行构建的;
  • 借助于webpack这个前端自动化构建工具,可以完美实现资源的合并、打包、压缩、混淆等诸多功能。
  • 根据官网的图片介绍webpack打包的过程
  • webpack官网

webpack安装的两种方式

  1. 运行npm i webpack -g全局安装webpack,这样就能在全局使用webpack的命令
  2. 在项目根目录中运行npm i webpack --save-dev安装到项目依赖中(webpack最新版为4,教程为3)(--save-dev参数缩写为 -D)npm i webpack -D【推荐】
  3. webpack-安装踩坑

webpack的核心概念

  • Entry

    • 代码的入口
    • 打包的入口
    • 单个或多个
  • Output

    • 打包成的文件(bundle)
    • 一个或多个
    • 自定义规则
    • 配合CDN
  • Loaders

    • 处理文件
    • 转化为模块
  • Plugins

    • 参与打包整个过程
    • 打包优化和压缩
    • 配置编译时的变量
    • 极其灵活

Entry

Output

Loaders

Plugins

webpack的基本使用

打包文件

  1. 建立了目录结构后,使用npm安装jQuery:npm init -y 然后npm i jquery -S
  2. .写main.js后, 输入命令编译js,webpack .\src\main.js -o .\dist\bundle.js

一些bug

解决:Error: Cannot find module 'webpack'
运行webpack报错:Cannot read property 'presetToOptions' of undefined
Webpack 3.X - 4.X 升级记录
webpack打包错误 ERROR in multi ./src/main.js ./dist/bundle.js

webpack基本配置

  • webpack.config.js
  • webpack-dev-server

为了实现自动打包,监听代码变化


可能遇到的问题


解决方案

webpack-dev-server配置命令的方式

  • --open 自动打开浏览器
  • --port 8000 指定端口
  • --contentBase src 内容的根路径
  • --hot 热重载热更新(不重新生成bundle.js,只生成补丁代码),实现浏览器不刷新重载(否则会页面整体刷新)

html-webpack-plugin插件

在内存中生成html页面的插件

安装

1.npm i html-webpack-plugin -D 2.在webpack.config.js导入插件
3.配置

优点

  • 指定生成页面的名称,重名即可,会自动访问同名的内存的页面。
  • 当使用 html-webpack-plugin之后,不再需要手动处理bundle.js的引用路径, 因为插件自动创建了一个合适的 script, 并引用了正确的路径

webpack中使用CSS(loader的使用)

  1. 在main.js中import CSS样式表,webpack默认只能打包JS类型的文件,需要手动安装一些合适的第三方loader加载器。
  2. 运行cnpm i style-loader css-loader --save-dev
  3. 修改webpack.config.js这个配置文件:
module: { // 用来配置第三方loader模块的
        rules: [ // 文件的匹配规则
            { test: /\.css$/, use: ['style-loader', 'css-loader'] }//处理css文件的规则
        ]
    }
  1. 注意:use表示使用哪些模块来处理test所匹配到的文件;use中相关loader模块的调用顺序是从后向前调用的;

使用webpack打包less文件

  1. 运行cnpm i less-loader less -D
  2. 修改webpack.config.js这个配置文件:
{ test: /\.less$/, use: ['style-loader', 'css-loader', 'less-loader'] },

使用webpack打包sass文件

  1. 运行cnpm i sass-loader node-sass --save-dev
  2. webpack.config.js中添加处理sass文件的loader模块:
{ test: /\.scss$/, use: ['style-loader', 'css-loader', 'sass-loader'] }

url-loader处理图片和字体

默认情况下,webpack无法处理css文件中的url地址,不管是图片还是字体库

  1. 运行cnpm i url-loader file-loader --save-dev (file-loader为url-loader的内部依赖,不需要配置)
  2. webpack.config.js中添加处理url路径的loader模块:
{ test: /\.(png|jpg|gif|jpeg)$/, use: 'url-loader' }
  1. url-loader会自动把图片转为base64编码,可以通过limit指定进行base64编码的图片大小;只有小于指定字节(byte)的图片才会进行base64编码:
  • 图片
{ test: /\.(png|jpg|gif)$/, use: 'url-loader?limit=43960' },
  • 字体
{test:/\.(ttf|eot|svg|woff|woff2)$/,use:'url-loader'}

默认改变图片的名字的原因是:防止重名,可以传参改变这一默认行为url-loader?limit=1024&name=[name].[ext],但为了防止重名,可以在原名字前添加hash值url-loader?limit=1024&name=[hash:8]-[name].[ext],hash最大为32位,所以最大只能设为32;

webpack.config.js 的 rules中的所有loader都能传参

webpack处理第三方文件的过程

  • 发现处理的文件不是JS,就去配置文件查找有没有对应的第三方loader规则;

  • 如果能发现对应的规则,就会调用对应的loader处理这种文件类型;

  • style-loader 与 css-loader 调用规则是从右到左调用。

  • 当最后的一个loader调用完毕,会把处理的结果交给webpack进行打包合并,最终打包构件;

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

推荐阅读更多精彩内容