Webpack Modules

Modules

模块化编程中,开发者将不相关的代码按照功能拆分,拆分后的代码叫做module
每个module都会提供独立的功能,比如做验证,debugging等,良好设计的module一般也会抽象的比较好,为整体应用提供相关功能而不侵入到业务代码。
Node.js从创立之初就支持模块化编程。在web领域,模块化编程也在慢慢崛起。
web领域很多工具都都在支持模块化编程,webpack在吸收其他工具的基础上,构建了一套自己的模块化工具。

What is webpack Module

对比Node.js modules,webpack modules支持多种方式实现模块化。
一些例子如下:

webpack 1需要特殊的loader来支持ES2015 import,而webpack2中不需要任何配置就可以使用该中方式。

Supported Module Types

webpack通过loaders支持很多种的语言,loader会将非js module添加到依赖bundle中。
webpack通过loader支持大部分的语言。

  • CoffeScript
  • TypeScript
  • ESNext(Babel)
  • Sass
  • Less
  • Stylus
    webpack不会限制使用何种工作流。

Module配置

文档地址

  • module.noParse(RegExp| [RegExp])
    指定webpack不出解析表达式匹配的文件。被忽略的文件不应该通过import,require,define或其他方式被调用。
    通过这样设置,忽略对大文件的处理后,可以提升构建速度。
noParse: /jquery|lodash/
  • module.rules(array)
    定义的规则会匹配module的创建。定义的规则可以设置module如何被创建,可以让module接收loader或修改默认的parser。

Rule

规则定义可以分为三部分,Conditions(条件),Results(结果),嵌套的规则。

Rule conditions

规则的条件包括两类:

  1. 请求的资源:请求的文件的绝对路径,通过resolve rules进行配置。
  2. 资源请求者:请求使用资源的文件的绝对路径,对请求资源使用使用import的位置。

举例:
app.js中引入css,import "./style.css".
请求的资源为/path/to/style.css.
资源请求者为/path/to/app.js.
规则定义中,test,include,exclude,resource属性需要匹配请求的资源。
issuer需要匹配资源请求者。

当设置多个条件时,需要匹配所有设置的条件。

Rule results

Rule results只在Rule condition匹配的时候起作用。
Rule中的值包括两个输出值。

  1. 使用的loader:匹配到resource上的一系列loader
  2. parser参数:module解析需要使用的配置。
    这些配置会影响loaders:loader,options,use.
    为了保证兼容性也支持:query.loaders

enforce配置会影响loader的分组,无论是normal,pre-loader或post-loader
parser属性会影响parser配置。

nested rules

嵌套规则可以通过rulesoneOf来配置。
在Rule condition匹配的情况下,会起作用。

  • Rule.enforce
    参数可能为prepost
    制定loader的分类,不对该参数做配置时表示使用normal loader。
    另外支持一种inlined loader,适用于内联的import/require
    loaders按照post,inline,normal,pre顺序执行。
    normal类型的loader使用!前缀
    normalpre类型的loader使用-!前缀
    normal``post,pre类型的loader使用!!前缀
    inline loaders!都是非独立loader,只能被loader生成的代码使用。
  • Rule.exclude
    Rule.excludeRule.resource.exclude的简写。
    具体详情参考Rule.resourceCondition.exclude
  • Rule.include
    Rule.includeRule.resource.include的简写。
    具体详情参考Rule.resourceCondition.include
  • Rule.issure
    通过issuer匹配的Condition,详情参考Rule conditions
  • Rule.loader
    Rule.loaderRule.use: [ { loader} ]的缩写。
    详情参考Rule.useUseEntry.loader.
  • Rule.loaders
    Rule.loadersRule.use的映射.
    该配置是为了兼容的原因才存在的。应该对Rule.use进行配置,来代替对该属性的配置。
    详情参考Rule.use
  • Rule.oneOf
    在一系列的Rules中进行匹配
  • Rule.options / Rule.query
    Rule.optionsRule.queryRule.use: [ { options} ]的简写.
    详情参考Rule.useUseEntry.options.
    Rule.query仅仅为了兼容老的,使用Rule.options来替代该配置。
  • Rule.parser
    parser的配置参数。
    An object with parser options. All applied parser options are merged.

For each different parser options object a new parser is created and plugins can apply plugins depending on the parser options. Many of the default plugins apply their parser plugins only if a property in the parser options is not set or true.

//默认plugin的parser配置项
parser: {
  amd: false, // disable AMD
  commonjs: false, // disable CommonJS
  system: false, // disable SystemJS
  harmony: false, // disable ES2015 Harmony import/export
  requireInclude: false, // disable require.include
  requireEnsure: false, // disable require.ensure
  requireContext: false, // disable require.context
  browserify: false, // disable special handling of Browserify bundles
  requireJs: false, // disable requirejs.*
  node: false, // disable __dirname, __filename, module, require.extensions, require.main, etc.
  node: {...} // reconfigure node layer on module level
}
  • Rule.resource
  • Rule.rules
  • Rule.test
    Rule.textRule.resource.test的缩写,
    详情查看Rule.resourceCondition.test
  • Rule.use

Condition

Conditions支持下面几种

  • string:同提供的string匹配。ie:文件夹绝对路径或文件绝对路径
  • RegExp:同提供的正则表达式进行匹配
  • Function:函数使用传入的值进行匹配,匹配成功返回true
  • 数组condition:至少需要匹配数组中的一个condition
  • object:需要匹配所有属性,每个属性都有默认值。

{ test: Codition }:必须要匹配Condition,该配置约定使用RegExp或RegExps数组。但是该配置不强制要求。

UseEntry(object)

必须要有一个string类型的值处理的loader。使用resolveLoader来解决loader的查找。
可以使用options参数来做配置,配置的内容会传递给loader。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,638评论 18 139
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,681评论 7 110
  • 无意中看到zhangwnag大佬分享的webpack教程感觉受益匪浅,特此分享以备自己日后查看,也希望更多的人看到...
    小小字符阅读 8,147评论 7 35
  • 说在前面:这些文章均是本人花费大量精力研究整理,如有转载请联系作者并注明引用,谢谢本文的受众人群不是webpack...
    RockSAMA阅读 6,914评论 2 7
  • 人生的错误莫过于我把你想的太简单,你把我想得太难 。
    片羽飞章之墨语轩袭阅读 161评论 0 0