Webpack Modules

作者: yftx_ | 来源:发表于2017-03-03 17:06 被阅读4897次

    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
      }
    }
    

    相关文章

      网友评论

        本文标题:Webpack Modules

        本文链接:https://www.haomeiwen.com/subject/bujrgttx.html