剥茧抽丝看懂别人的webpack框架(1)

备注(写这么个标题主要是明确的吸引和我曾经有同样问题的人,当我写vue时急于求成我直接用了官方的脚手架,并没有自己搭建,结果我只知道表面怎么用,并不知道为什么,更不知道怎么改其中的配置,幸亏官方的脚手架比较好。但是你要用react ,jquery和webpack配合时,对于一些像我一样的入门级选手就不知所措了。尤其你要想随心搭建框架就更别提了。在此写下我在了解webpack上遇到坑,解决的经验,对于入门的你有用最好,也作为自己的一个笔记,如有错误请留言告知,我会非常感谢)

对于初学者首先要看入门的webpack官方网站学习基本功,但是由于我们想快速上手,往往上网找来xxx现成的框架,想先练习一下。但是你可能看到很多版本,现在我选三个不同难度的例子来分析(第一个例子)(第二个例子)(第三个例子

你按照这些例子抄一遍你都能运行起来的,后两个是react+webpack项目,但是我们讲的是webpack,这没关系,只要你懂了webpack是怎么回事,以后和谁一起搭建都没关系,主要是你懂他是怎么运行的就行。

如果你用过grunt,gulp这些打包工具你用webpack就回上手很容易,但是在此我就当我们从零开始。

(一)、第一个例子,主要写了webpack+webpack-dev-server纯原始的用法;
首先都要全局安装webpack和webpack-dev-server;因为你要用webpack在终端进行打包编译,而webpack-dev-server你要用它进行代理服务的功能,也要全局安装。

1、用webpack进行编译:webpack 会把entry.js文件编译到新创的bundle.js文件中

终端中运行:webpack ./entry.js bundle.js

2、用webpack进行监听:webpack 能将不变的模块进行缓存并与改变的模块一起重新编译输出。

终端中运行:webpack --watch

3、安装webpack-dev-server:(开发一个本地服务,在没有本地服务时每次都的刷新页面,并且是从本地打开,细节在第一个例子中可以看到)

终端中运行:webpack-dev-server

在浏览器中打开http://localhost:8080/webpack-dev-server/或者http://本地IP地址:8080/webpack-dev-server/(端口号默认是8080可以修改,webpack有相应的文档配置)

4、webpack打包到xxx路径下的xxx文件包
这里我们的路径是dist,文件包叫bundle.js

在终端中运行:webpack --entry ./entry.js --output-path dist --output-file bundle.js


对于基本的webpack命令大体上我们就用到这些,下面来看第二个例子中这些命令会得到封装,通过npm进行调用。
(二)、第二个例子是webpack+react,用的webstorm编辑器(在此我建议各位如果对webstorm了解不深的话,请不要用webstorm运行npm安装的大型项目,会把编辑器托死,尤其项目中有自动化测试部分,我用的是vsCode编辑器轻便,灵活。你也可以用其他更好用的,欢迎推荐给我)
这个例子的作者写的很清楚,在此我只把它webpack运行这部分拿来做对比,其他配置建议看官方文档
下面这段代码我们经常在很多package.json文件中看见,这是为了我们让npm给我做一个代码运行的代理;

"scripts": {
"build":"webpack",
"dev":"webpack-dev-server --devtool eval --progress --colors --content-base build"
}

当你运行npm run dev时其实只是类似这样一个过程:
npm run dev -----查询packge.json文件中dev,执行具体命令------>webpack-dev-server --devtool eval --progress --colors --content-base build

所以这些真正的在做事情的还是第一个例子中哪些代码,注重基础,懂原理才能走的更远;


(三)、第三个例子这位作者写非常好,体系完整,React Starter Kit,React+redux+webpack+express等还有自动化测试这部分,如果你用react可以了解一下

首先我们看它的package.json文件中的scripts部分,他这个项目安装了better-npm-run来优化npm配置文件的写法,所以我们的看betterScripts具体的配置信息

"betterScripts": {
  "compile": {"command":"node bin/compile",
                    "env": {"DEBUG":"app:*"}
       },
  "start": {"command":"node bin/server",
                    "env": {"DEBUG":"app:*"}
     },

由于项目大所以我只对比webpack运行编译这部分,其他的webpack配置部分以后会有具体说明;
这里你要启动项目你可以在终端中运行

npm run start

这部分过程时这样的:
npm run start------查询packge.json文件中scripts里的start,执行具体命令------>better-npm-run start------查询packge.json文件中betterScripts里的start,执行具体命令--------->
node bin/server----------node 启动跟路径下的bin文件夹下的server文件------------>执行server文件中的具体配置,这个项目用了express发送服务给webpack-dev-server

所以你在终端运行npm run start,better-npm-run start(必须安装better-npm-run),
node bin/server都是行,不管怎么配置核心不便,只是形式更便于项目的开发;


webpack-dev-server 是一个小型的Node.jsExpress服务器,它使用webpack-dev-middleware来服务于webpack的包. 它也有一个微运行时是通过Sock.js连接服务器

Express会在后台调用http模块(node.js的),因为Node会自动解析依赖关系,开启服务。

(SockJS是一个浏览器的JavaScript库,它提供一个WebSocket-like对象。SockJS给你一个清晰,兼容的Javascript API,在浏览器和web服务器之间创建一个低延迟,全双工,跨域的通信通道。)


具体了解:
webpack-dev-server
webpack(如果你没认真看过webpack,希望你有时间多看看)
better-npm-run(优化npm,有助于解决跨平台运行
Express (丰富的 HTTP 快捷方法和任意排列组合的 Connect 中间件,让你创建健壮、友好的 API 变得既快速又简单。)
pathNode.js path模块提供了一些用于处理文件路径的小工具)
node文档

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

推荐阅读更多精彩内容