codecamp

Webpack:解析器(Resolvers)

解析器是使用 ​enhanced-resolve​ 库创建的。​Resolver​ 类 拓展了 ​tapable​ 类,并使用 ​tapable​ 来提供了一些钩子。 ​enhanced-resolve​ 可以直接用于创建新的解析器, 但是任何 ​compiler​ 实例 都有一些解析器实例,可以被 ​tap​ 进去。

在继续阅读之前,请确保你已经读过 ​enhanced-resolve​ 和 ​tapable​ 文档。

类型

在 ​compiler​ 类中,提供了三种类型的内置解析器:

  • normal​: 通过绝对或相对路径解析模块。
  • context​: 在给定的上下文中解析模块。
  • loader​: 解析 webpack loader。

根据需要,任一个被使用在 compiler 中的内置解析器, 可以通过插件进行定制:

compiler.resolverFactory.hooks.resolver
  .for('[type]')
  .tap('name', (resolver) => {
    // you can tap into resolver.hooks now
    resolver.hooks.result.tap('MyPlugin', (result) => {
      return result;
    });
  });

其中,​[type]​ 是上述三个解析器之一。

配置选项

上述解析器也可以 利用 ​resolve​ 或者 ​resolveLoader​ 选项,通过配置文件进行定制。这些选项允许 用户可以通过多种选项来更改解析行为,包括 通过解析 ​plugins​。

解析器插件,例如:​DirectoryNamedPlugin​,可以直接引入 在 ​resolve.plugins​,而不是直接在 ​plugins configuration option​ 中使用。


Webpack:Plugin API
前言
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }