webpack 入门实践(一)

webpack 对于前端开发工程师可能并不陌生。webpack 是前端资源模块化管理和打包工具,可以将许多松散的模块按照依赖和规则打包符合生成环境部署的前端资源。webpack 可以按需加载的模块进行代码分隔,也可以异步加载所需模块。webpack 通过 loader 的代码转换,可以将任何形式的资源都视为模块(CommonJS 模块 AMD 模块 ES6 CSS JSX Json less sass)来加载。

多当下 modern 框架都使用 webpack 作为项目管理和打包工具

目标:掌握 webpack,并可以将他实际应用到项目中。

基本要求:熟悉 javascript 的前端工程师

安装 webpack

创建一个项目(创建一个文件夹,使用 npm init -y 初始化项目)

首先需要全局安装 npm install -g webpack(-g 表示全局安装)

然后在项目下运行 npm install webpack --save-dev 命令来安装 webpack

然后创建一个简单项目以便演示 webpack 是如何管理和打包前端项目,项目结构如下图。

打开 index.html 看一下效果,很简单,单击“隐藏列表”按钮,隐藏列表然后按钮文字变为“显示列表”。再次单击按钮来显示列表。

在 package.json 添加 build 脚本来执行 webpack 第一个参数为入口文件 第二个参数为输出文件。

简单说明一下 dom-loader.js 中提供了通过 document.querySelector 获取的一系列 dom 对象。要使用 webpack 将文件中的 dom 对象 export 给 app.js (以使用),我们需要对文件 dom-loader.js 进行处理,通过 export 关键将这些 dom 向外 export。


然后在 app.js 可以将这些 dom 对象导入来使用

这样我们就在 app.js 和 dom-loader.js 建立了依赖关系。

在终端(cmd)中运行 npm run build 后,在目录下多了 dist/bundle.js(我们在命令行定义出口文件)

写下来在 index.html 中将 webpack 生成的 bundle.js 引入。注释掉原有 dom-loader.js 和 app.js 文件。

如果在 webpack 命令上添加 -p(压缩生成 bundle.js) 以完成部署时所需的 js 文件。

打开通过运行 npm run build:prod 命令生成的 bundle.js 如下图。

打开 chrome 浏览器的开发者工具来查看文件,发现文件都是 0b

我们需要启动服务来启动项目

webpack-dev-server是一个小型的Node.js Express服务器,它使用webpack-dev-middleware来服务于 webpack的包,除此自外,它还有一个通过Sock.js来连接到服务器的微型运行时.

devserver 作为 Webpack 配置选项中的一项,具有以下配置选项

 contentBase 默认 webpack-dev-server 会为根文件夹提供本地服务器,如果想为另外一个目录下的文件提供本地服务器,应该在这里设置其所在目录(本例设置到“public"文件夹下).

 port 设置默认监听端口,如果省略,默认为"8080".

inline 设置为 true,当源文件改变时会自动刷新页面.

historyApiFallback 在开发单页应用时非常有用,它依赖于 HTML5 history API,如果设置为 true,所有的跳转将指向 index.html.

安装 webpack-dev-server

然后在 package.json 文件中在 build 脚本将 webpack 替换为 webpack-dev-server 后运行 npm run build 就会在终端看到下面内容,我们项目部署到服务 localhost 的 8081 端口下。

删除 build:prod 生成的 dist 文件夹后会看到下面错误。是因为 webpack-dev-server 并不是实际生产 bundle.js 而是将 bundle.js 写入内存供 index.html 使用。如果不指定 --output-filename ,index.html 就无法找到 bundle.js 文件。

我们还需要对 build 脚本进行一些修改,

webpack-dev-server --entry ./src/js/app.js --output-filename ./dist/bundle.js 这样

**修改一下项目结构,将 index.html 从 src 目录中移出到根目录下

开始写 webpack 配置文件

webpack 配置文件,在根目录下创建 webpack.conig.js ,也可以根据需要使用其他名称。但如果使用 webpack.config.js 无需指定 webpack 会自动读取该文件进行操作。webpack.config 需要有一定固定的结构。我们使用 nodejs 的模块方式向外提供 config 对象

entry:可以指定一个入口起点(或多个入口起点)

output:path 应该是一个绝对路径,这一点与入口文件路径为相对路径不同。因为 webpack 需要在这个路径创建文件并写入内容。

在 package.json 修改一下脚本,在运行命令时,webpack 会读取 webpack.config.js 中配置来找到入口文件,然后将他打包到 webpack。

测试一下 build:prod,然后看效果,没问题。

但是运行 build 脚本时,就报错出现问题,因为 webpack-dev-server 需要配置一下 publicPath 这个参数。

大家发现我们在 index.html 以 link 方式引入 css 文件

loader 用于对模块的源代码进行转换 loader 将内联图像转换为 data URL,甚至允许你直接在  JavaScript 模块中 import CSS文件

安装 style-loader css-loader 加载器来将 css 打包到 bundle.js 中。

然后在 app.js 中将其引入

test: 一个匹配 Loaders 所处理的文件的拓展名的正则表达式(必须)

rules: 允许你在 webpack 配置中指定多个 loader。。

要将  css 文件导入到 javascript 文件中需要使用 css-loader.

注释掉 index.html 中的 link 取消引用的样式,然后运行 npm run build 发现样式丢失了

因为 css-loader 仅是将 css 加载到 javascript 文件中,并没有将样式表写入到 html 中,所以我们看不到效果。需要加载 style-loader 来完成这个任务。

** 注意加载器的顺序

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

推荐阅读更多精彩内容