我意外地在一个javascript模块上使用了require(),这个模块打算与浏览器一起使用。模块设置this['libraryName'] = ...。我注意到它确实奏效了。
所以,我创建了两个文件:
test1.js
console.log( require('./test2.js'))test2.js
console.log(this === module.exports)
this.SOMETHING = 10结果是什么呢?
$ node ./test1.js
true
{ SOMETHING: 10 }
$我没想到会这样!该true意味着module.exports与全局上下文中的this相同。
specs?
typeof require === 'undefined'呢?非常重要的事情。
发布于 2020-02-26 14:49:00
这并不是什么新鲜事:
这意味着,在浏览器中,如果您处于全局范围var中,就会定义一个全局变量。在different.中,这是Node.js
当一些事情是不同的,它们肯定不是任何规范的一部分。
不知道怎么做。在node.js中,this.SOMETHING = 10只将一个名称(module.exports)更改为另一个名称(this)。没别的了。
如果您尝试使用webpack或<script type="module" src="..."></script>将<script type="module" src="..."></script>导入浏览器,那么在这两种情况下您都将获得TypeError: undefined has no properties。
typeof require === 'undefined'也许你会更好的与browser-require,browserify或诸如此类的。
https://stackoverflow.com/questions/59763150
复制相似问题