3分钟了解webpack

webpack是啥

webpack是一款强大的前端模块管理和打包工具。类似broserify工具,但是功能更强大。

  • 同时支持CommonJS和AMD模块(这两者是js模块管理的两大规范,CommonJS是同步加载,后者是异步加载通过requireJS等工具用于前端)
  • 串联式模块加载器及插件机制,有更好灵活性和扩展性
  • 可以基于配置智能分析打包多个文件,实现公共模块按需加载
  • 在内存中打包,性能更快

webpack将项目中的一切资源都视为模块,分析其依赖,而生成静态资源。

//webpack.config.js
var webpack = require('webpack')

module.exports = {
    entry: { a: "./a", b: "./b" },
    output: {
        path: path.join(__dirname, 'dist'),
        filename: '[name].js'
    },
    module: {
          // 
    }
    plugins:{
          //
    }
    resolve:{
          //
    }
}

entry参数定义了打包后的入口文件,可以是个字符串或数组或者是对象;如果是数组,数组中的所有文件会打包生成一个filename文件;如果是对象,可以将不同的文件构建成不同的文件。
output参数是个对象,定义了输出文件的位置及名字,
像上面就会在指定目录中输出a.js和b.js

Loaders(模块加载器)

这是webpack里最重要的特性,除了纯js外,每种资源都可以通过对应的加载器处理成模块,这样我们就可以通过require来加载任何类型的文件或模块,比如CoffeeScript/less/sass/图片等。而且,webpack的加载器之间可以串联,通过感叹号连接,一个加载器的输出可以成为另一个加载器的输入,顺序是从右向左。比如less文件通过less-load处理成css,然后通过css-loader加载成css模块,最后由style-loader加载器对其最后处理可以应用到最终浏览器环境。

module: {
    loaders: [{
        test: /\.js$/,
        exclude: /node_modules/,
        loader: 'babel?presets[]=es2015&presets[]=react'
    }, {
        test: /\.less$/,
        loader: 'style-loader!css-loader!postcss-loader!less-loader'
    }, {
        test: /\.css$/,
        loader: 'style-loader!css-loader!postcss-loader'
    }]
}


test:以正则表达式指定文件,exclude:指明忽略检测哪些文件夹中的内容,loader:就是要使用的加载模块。其中
loader:'babel?presets[]=es2015,presets[]=react'
babel可以支持ES6和react语法的转换,
问号指的是查询使用的参数,也可以写成:

loader:'babel',
query:{
        presets:['es2015','react']
}

css相关的
css-loader是加载我们的css
style-loader把读取到的css内容全部插入到页面

使用preLoaders和postLoaders

preLoaders是在loaders执行之前处理的,postLoaders是loaders之后执行。我们在书写的时候可以在preLoaders中添加jshint来检查自己的代码是否合乎规范。

module:{
    preLoaders:[{
        test:/\.js$/,
        exclude:/node_module/
        loader:'jshint-loader'
    }]
    ...
},
//配置jshint的选项,支持es6的校验
jshint: {
 "esnext": true
},

plugins

当loaders不能满足我们的开发需求时,plugins为我们提供了丰富的插件系统。

plugins: [
    //抽离出公共部分
    new webpack.optimize.CommonsChunkPlugin("common", "common.js"),
    //独立出css样式
    new ExtractTextPlugin(
        path.join('../../stylesheets', project, "/[name].css")
    )
    //webpack提供的插件,可将全局变量插入到所有代码中
    new webpack.ProvidePlugin({
        $: "jquery",
        jQuery: "jquery",
        "window.jQuery": "jquery"
    })
]

resolve

webpack在构建包的时候会按目录进行文件查找,属性中的
extensions数组中用于配置程序可以自行补全哪些文件后缀;
alias 为模块别名定义,方便后续直接引用别名,无须多写长长的地址

resolve: {
    extensions: ['', '.js', '.json', '.scss'],
    alias: {
        'underscore.js': path.resolve(__dirname, '../src/vendor/underscore/underscore.js'),
    }
}

【参考】
这是更完整的讲解入门webpack的文章:http://www.ido321.com/1646.html
这篇讲的也很详细:https://zhuanlan.zhihu.com/p/20397902
这是webpack开发中的实践总结,系列干货文章:
http://www.jianshu.com/notebooks/4015198/latest

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

推荐阅读更多精彩内容

  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,157评论 7 35
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,685评论 7 110
  • 前言 WebPack 是什么? WebPack 是什么,WebPack 可以看做是模块打包机:它做的事情是,分析你...
    Promise__阅读 1,125评论 3 12
  • webpack 介绍 webpack 是什么 为什么引入新的打包工具 webpack 核心思想 webpack 安...
    yxsGert阅读 6,461评论 2 71
  • 找不出话题 连创作都失去了激情 好吧 就这样颓废到底
    慕星读者OR独者阅读 235评论 0 0