webpack3.0入门

1.全局安装webpack npm install -g webpack ,   查看webpack版本号  webpack -v

2.npm init -y 初始化项目,生成pageage.json 文件

3.npm install --save-dev webpack

4.创建文件目录

1)在根目录下创建一个 src 文件 ,用于存放编写的源码,创建一个dist文件夹用于存放打包之后的代码,用于发布,在dist目录下创建一个 index.html

2)在src/entery.js ,创建一个js的入口文件

3)执行webpack src/entery.js dist/bundle.js

5.使用webpack.config.js 配置文件进行配置

    1.entry: {}配置入口文件

    2.output: {} 出口文件,

    3.module:{rules:[]} 配置loader

    4.plugins:[]配置插件

    6.devServer: {}配置服务, 热跟新服务, 3.5版本以上的webpack 自动配置热更新,webpack-dev-server,下载,在package.json中配置

6.loader介绍

    style-loader : css 中的 url 路径处理

    css-loader:  识别标签中的 id class 属性

    file-loader:    解决打包后文件路径不一致的问题,

    url-loader:   当图片小于一个值,打包成base64的

7.压缩js代码

    1. uglify.js-webpack-plugin  插件  使用    new uglify() 这个插件不需要安装

    2. html-webpack-plugin 插件html文件的打包,需要npm install 安装这个插件

    3.extract-text-webpack-plugin  css分离的插件,需要下载

8.html文件打包

    1、

9.css分离和publicPath的使用, 在output属性中配置publicPath 路径

    图片配置loader时候options选项中配置outputPath,选项, ‘images/’

10.html文件中引入img是如何处理 

    使用html-withimg-loader 这个loader , 在rules 中进行配置 

11.less和sass的打包与分离

    less: less 需要下这两个包 less less-loader,

    sass : node-sass sass-loader, 注意 分离和css。less ,sass 三个的分离方式一样,注意sass 插件,文件后缀是 .scss

12.消除无用的 css 需要使用webpack的插件 purifycss,  需要下载 purifycss-webpack基于 purify-css,所以两个都需要下载 

    在配置文件中 ,首先引入node 的glob 模块,再引入 purifycss-webpack插件,在plugins选项中进行配置

13.打包之后的代码如何调试

    devtool :配置项,source-map 生产独立的map文件, 独立,包括行与列,就是指提示错误的时候,提示第几行第几列,打包最慢,包含内容多

                                cheap-module-source- map 只包括行的 map ,就是提示错误的时候只报第几行,独立性,单独的.map文件

                                eval-source-map 不会单独生产独立的map文件,有安全问题,一定在开发阶段,有性能稳定,包括行列

                                cheap-module-eval-source-map   ,只包括行、

    devtool: 开发调试模式,设置开发调试模式

14.babel 相关配置,下载依赖包 babel-core 核心 babel-loader , 需要转换的语法 babel-preset-es2015  babel-preset-react,

    在配置项,rules中配置需要转换的文件 如 : js/jsx 要转化, 排除node_modules(exclude属性排除),及相关的配置项,由于options{}对象中需要配置的东西比较多,故因此需要专门建一个babel的配置文件,放在根目录中  建立一个 .babelrc的文件,里面放一个json对象

    只配置es2015就是es6语法可以转化,如果是es7,es8的话需要安装 babel-preset-env, es6 es7 es8 都可以转换,所以在babel的配置文件,babelrc中,配置一个env就可以啦

15.模块化配置配置webpack.config.js文件

16,环境区分, --save-dev 安装开发依赖,在pakeage.json文件下 devDepencice中存放, --save 开发依赖, 在depanceice存放

node 指令传值 set type=dev&webpack    使用process.env.type === 'dev',

17.webpack自动打包, webpack --watch,这个指令就是可以更改文件后自动打包,但是有时候需要配置项,在webpack.config.js中,需要配置watchOptions选项

18.打包之后文件 的署名信息, 通过webpack的一个自带的插件 webpack.BannerPlugin('署名信息')

19,引入第三方库,如 jquery vue react ,需要使用webpack自带的插件  webpack.ProvidePlugin({jquery: 'jquery'}),先下载依赖包

20.集中拷贝静态资源, ,使用webpack的插件,需要单独下载, copy-webpack-plugin,  使用方法 :new copyWebpackPlugin([{

    from: __dirname+'/src/public',// 拷贝的目标路径

    to: './public' // 放到的位置, 相对位置,相对于出口设置的位置,也就是 dist目录下

}])

21.设置 json文件,要是用的,就是普通文件的引入,另外,低版本的 webpack 直接webpack-dev-server 命令不会自动刷新的话,需要设置一个webpack的插件 webpack.HotModuleReplacementPlugin()

22.webpack优化小技巧(黑技能)

a.引入第三方库的时候,不要在js文件中引用 ,在配置文件中配置 webpack.provideplugin(),好处:js文件中使用了第三方库才会打包第三方库,不使用的情况,不会给打包 

b.抽离入口文件,公共文件 new webpack.optimize.CommonsChunkPlugin({})

23 . webpack.js.org  

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

推荐阅读更多精彩内容

  • 我喜欢安静的坐着,却在别人看不到的我的内心,或许上演着一部精彩的宫斗戏,武打戏。 我喜欢这个不同性格的我。 ...
    易安Ann阅读 247评论 0 0
  • 一直恐于 看人眼睛 说不上缘由 或许是担心 最薄弱的一面 被赤裸裸读透 当看到喜欢的人 心会跳脸会红 生怕被发现不...
    黄土高坡上的风姑娘阅读 133评论 0 0