webpack使用Symbol.toStringTag(Symbol.toStringTag用法)
Symbol.toStringTag是一个内置 symbol,它通常作为对象的属性键使用,对应的属性值应该为字符串类型,这个字符串用来表示该对象的自定义类型标签,通常只有内置的Object.prototype.toString()方法会去读取这个标签并把它包含在自己的返回值里。
| Symbol.toStringTag属性的属性特性: | |
|---|---|
| writable | false |
| enumerable | false |
| configurable | false |
Symbol.toStringTag用法
Symbol.toStringTag 作用
对象上的Symbol.toStringTag属性用于对象toString类型标识
Symbol.toStringTag 解释
对象调用toString方法,如果这个属性存在,它的返回值会出现在toString方法返回的字符串之中,表示对象的类型。
webpack中也有使用,用于定义模块导出exports添加Module类型的属性
webpack使用Symbol.toStringTag
export.toString(export);
function __webpack_require__() {
// ....
}
__webpack_require__.r = function(exports){
if (typeof Symbol !== 'undefined' && Symbol.toStringTag) {
Object.defineProperty(exports, Symbol.toStringTag, {value: 'Module'});
}
Object.defineProperty(exports, '__esModule', {value: true});
}
const exports = {};
__webpack_require__.r(exports);
console.log('exports', exports);
// {__esModule: true, Symbol(Symbol.toStringTag): "Module"}
console.log('exports toString', exports.toString());
// [object Module]总结
Symbol.toStringTag属性可以用来定制toString方法返回[object Object]或[object Array]中object后面的那个字符串标识对象类型
到此这篇关于webpack使用Symbol.toStringTag(Symbol.toStringTag用法)的文章就介绍到这了,更多相关Symbol.toStringTag用法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Three光源Target位置改变光照方向不变的问题解决方法
这篇文章主要为大家介绍了Three光源Target位置改变光照方向不变的问题及解决方法,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-12-12
浅析使用BootStrap TreeView插件实现灵活配置快递模板
这篇文章主要介绍了使用bootstrap-treeview插件实现灵活配置快递模板的相关资料,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下2016-11-11
JavaScript实现JSON合并操作示例【递归深度合并】
这篇文章主要介绍了JavaScript实现JSON合并操作,结合实例形式分析了javascript基于递归深度实现json合并操作相关实现技巧与注意事项,需要的朋友可以参考下2018-09-09


最新评论