webpack umd library only for root, replace exports

广告位招租
扫码页面底部二维码联系

webpack 导出的 umd 模块在传【作者:唐霜】【访问 www.tangshuang.net 获取更多精彩内容】入了 output.library 的情【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net况下,会输出四个条件语句,大概如下:

【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。
if(typeof exports === 'object' && typeof module === 'object')
  module.exports = factory(require("a"), require("b"));
else if(typeof define === 'function' && define.amd)
  define(["a", "b"], factory);
else if(typeof exports === 'object')
  exports["o"] = factory(require("a"), require("b"));
else
  root["o"] = factory(root["a"], root["b"]);

这样的 umd 模式。其中,关于依赖、导【原创内容,转载请注明出处】【转载请注明来源】出接口名都可以定制,其中依赖部分通过 e未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。xternals 配置来定制,导出接口名【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。通过 library 来定制。

转载请注明出处:www.tangshua原创内容,盗版必究。未经授权,禁止复制转载。ng.net【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】et 获取更多精彩内容】原创内容,盗版必究。【版权所有,侵权必究】

但是,现在的一个情况是,在第三个条件句,【原创不易,请尊重版权】【版权所有,侵权必究】即红色部分,这个部分会在标准的 comm本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。onjs 中被引用。所谓标准的 comm转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】onjs 是由 commonjs 官方定转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】义的,只有 exports 和 requ著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】ire 两个关键字的模块方案。而 nod【作者:唐霜】【作者:唐霜】ejs 虽然遵循 commonjs,但是【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】在其基础上实现了 module 关键字,【作者:唐霜】【版权所有,侵权必究】将 exports 作为 module.【作者:唐霜】本文作者:唐霜,转载请注明出处。exports 的引用,因此被成为 co【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.netmmonjs2。

【版权所有,侵权必究】转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。【转载请注明来源】ng.net

我们现在去看这个部分,倘若一个模块在遵循【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net标准 commonjs 的情况下,导出如转载请注明出处:www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】下:

本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】未经授权,禁止复制转载。ang.net
// a.js
exports.a = function a() {}
// b.js
exports.b = function b() {}
// main.js
export.a = require('./a.js')
export.b = require('./b.js')

外部使用这个包,实际上应该是:

【关注微信公众号:wwwtangshua本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】ngnet】未经授权,禁止复制转载。【作者:唐霜】本文作者:唐霜,转载请注明出处。
const { a, b } = require('./main.js')

但是在 webpack 的 umd 模块【未经授权禁止转载】【原创内容,转载请注明出处】下使用时变成了:

原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。
// bundle.js
exports.o = factory()

那么在外面的其他程序去用这个包时就需要变【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】成下面这种方式才可以:

原创内容,盗版必究。【关注微信公众号:wwwtangshua未经授权,禁止复制转载。【未经授权禁止转载】ngnet】转载请注明出处:www.tangshua未经授权,禁止复制转载。原创内容,盗版必究。ng.net【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【本文受版权保护】ngnet】
const { o } = require('./bundle.js')
const { a, b } = o

这显然不符合我们的期望,我们希望即使 w【原创不易,请尊重版权】未经授权,禁止复制转载。ebpack 打包之后,仍然保持原有的使【原创不易,请尊重版权】【访问 www.tangshuang.net 获取更多精彩内容】用方式。所以,我写了一个方法来修改这个部【未经授权禁止转载】【未经授权禁止转载】分的输出,经过处理之后,webpack 【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】这个部分的输出将会是:

本文作者:唐霜,转载请注明出处。原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。【本文受版权保护】
else if(typeof exports === 'object')
	{ var a = factory(require("a"), require("b")); for (var i in a) exports[i] = a[i]; }

即替换掉原来的输出形式,将原本的输出接口【转载请注明来源】【作者:唐霜】直接赋值到 exports 上,这样就保原创内容,盗版必究。未经授权,禁止复制转载。持了原本的逻辑。

原创内容,盗版必究。【原创不易,请尊重版权】

具体做法如下:

著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshuangnet】ngnet】
// webpack.config.js
const { bufferify } = require('webpack-bufferify')
const plugins = [
  bufferify(function(content, file, assets, compilation, compiler) {
    if (file.split('.').pop() !== 'js') {
      return
    }
    const { optimization } = compiler.options
    content = content.toString()
    content = optimization.minimize === true
      ? content.replace(/exports\[.*?\]=(.*?):/, `function(e,a){for(var i in a)e[i]=a[i]}(exports,$1):`)
      : content.replace(/exports\[.*?\](.*?);/, `{ var a$1; for (var i in a) exports[i] = a[i]; }`)
    return content
  }),
]

module.exports = {
  ...,
  plugins,
}

webpack-bufferify 是我【版权所有,侵权必究】【版权所有,侵权必究】写的一个组件,用以替换 webpack 本文作者:唐霜,转载请注明出处。原创内容,盗版必究。输出的结果内容。通过上面的处理,就可以实转载请注明出处:www.tangshuang.net【版权所有】唐霜 www.tangshuang.net现我们的目的。

【访问 www.tangshuang.n【原创不易,请尊重版权】【未经授权禁止转载】et 获取更多精彩内容】【本文受版权保护】【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netang.net【作者:唐霜】