29.webpack——library与libraryTarget的用法/如何打包一个库文件

【重学webpack系列——webpack5.0】

1-15节主要讲webpack的使用,当然,建议结合《webpack学完这些就够了》一起学习。
从第16节开始,专攻webpack原理和高级API,只有深入原理和高级API,才能学到webpack设计的精髓,从而将技术点运用到实际项目中。
可以点击上方专栏订阅哦。

以下是本节正文:


commonjs与commonjs2的区别

// commonjs
exports.add = function(a, b){
    return a + b;
}
// commonjs2
module.exports = {
    add(a, b){
        return a + b;
    }
}

library与libraryTarget

  • library为导出库的名称
  • libraryTarget为导出结果的形式
    • var
    • commonjs
    • commonjs2
    • this
    • window
    • global
    • umd

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-db6MdAKq-1629172313136)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813142617850.png)]

上面var的模式,在webpack中就会编译成:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0Qli4bUO-1629172313139)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813142743917.png)]


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-R8tj20q6-1629172313140)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143523320.png)]

(上面最后一条注释请忽略)

如果libraryTargetcommonjs的话,webpack中就会编译成:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3CruM7g5-1629172313143)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143235125.png)]

**特别注意:**这个图是修改过了,请自行查看编译后的内容,exports.calculator = exports;这是会有问题的,原因是:webpack返回的是module.exports,而不是exports,所以,如果光给exports赋值的话,module.exports还是为初始值,即{},那么引入的时候还是{} —— 这一点也是libraryTarget为commonjs时,会导致的问题!

举个例子:

// a.js
exports = {age: 10}

// Index.js
const obj = require('./a.js')
console.log(obj) // {}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-HctxNb5V-1629172313147)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143550988.png)]

(上面最后一条注释请忽略)

如果libraryTargetcommonjs2的话,webpack中就会编译成:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-w0Lj2Mvx-1629172313148)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143650064.png)]

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-jLeYLSDY-1629172313149)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143745514.png)]

(上面最后一条注释请忽略)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-eyWmFOhN-1629172313150)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813143808594.png)]

注意:webpack返回的是module.exports,而不是exports,所以,如果光给exports赋值的话,module.exports还是为初始值,即{},那么引入的时候还是{} —— 这一点也是libraryTarget为commonjs时,会导致的问题!

举个例子:

// a.js
exports = {age: 10}

// Index.js
const obj = require('./a.js')
console.log(obj) // {}

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UM4k6FWt-1629172313151)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813172005475.png)]

(上面最后一条注释请忽略)

导出的内容会挂载到this上,而这个this=module.exports=exports,所以this就是我们导出的内容

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-1nJhvEAE-1629172313152)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813172453783.png)]


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6KVFgSN8-1629172313153)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813180701012.png)]

(上面最后一条注释请忽略)

window代表导出的内容挂载到window上


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WiXjS32C-1629172313154)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813180739162.png)]

(上面最后一条注释请忽略)

global代表导出的内容挂载到global上


[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-2LwTwXQD-1629172313155)(C:\Users\yuhua7\AppData\Roaming\Typora\typora-user-images\image-20210813181017005.png)]

(上面最后一条注释请忽略)

umd的话,会根据导出的数据类型,去走不同的逻辑。也就是同时支持commonjs、commonjs2、amd、全局变量等。比如moment这个库用的就是umd

(function webpackUniversalModuleDefinition(root, factory) {
  if(typeof exports === 'object' && typeof module === 'object') // 如果exports是对象并且commonjs2中的module是对象
    module.exports = factory();// commonjs2才有modle
  else if(typeof define === 'function' && define.amd)
    define([], factory);// 如果define是函数并且define.amd存在,也就是说是amd
  else if(typeof exports === 'object')
    exports['MyLibrary'] = factory(); // 如果是对象
  else
    root['MyLibrary'] = factory(); // 全局变量
})(typeof self !== 'undefined' ? self : this, function() {
  return _entry_return_;
});

另外:cmd、amd已经退出历史舞台了,淘汰了

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值