typeof string 怎么不是 instanceof String 呢? [复制]
Posted
技术标签:
【中文标题】typeof string 怎么不是 instanceof String 呢? [复制]【英文标题】:How is typeof string not an instanceof String? [duplicate] 【发布时间】:2020-05-15 17:32:54 【问题描述】:在下面的代码中,如果something
和arbit
中的typeof
出来是string
,为什么instanceof String
不返回true
:
const roles = ['something', 'arbit'];
console.log("Array.isArray(roles):", Array.isArray(roles));
console.log("roles instanceof Array:", (roles instanceof Array));
roles.forEach(element =>
console.log(`[$element]`);
console.log(`\ttypeof($element):`, typeof(element));
console.log(`\t$element instanceof String:`, (element instanceof String));
);
这个的输出是:
Array.isArray(roles): true
roles instanceof Array: true
[something]
typeof(something): string
something instanceof String: false
[arbit]
typeof(arbit): string
arbit instanceof String: false
此外,roles instanceof Array
的计算结果为 true
。彻底糊涂了。
这是在 Nodejs 12 中运行的纯 javascript,尽管我怀疑这有什么不同...
【问题讨论】:
这可能会有所帮助,***.com/questions/899574/… @FoggyDay 这与 Typescript 有什么关系,我使用的是纯 JavaScript。我错过了什么吗? @JazzBrotha 这很有帮助,谢谢! 有帮助,但真正的问题是“字符串”与“字符串”。请参阅Evert's 回复和this 线程。 【参考方案1】:Javascript 有两种主要的方式来生成字符串,作为文字:
const foo = "hi";
通过字符串构造函数
const bar = new String("hi");
这些不是一回事。第二个会慢一些,并且有细微的行为差异。
所以instanceof String
不起作用的原因是因为您的文字字符串不是此类的实例。
通常你会想要避免new String()
。
【讨论】:
这是正确答案。 this 线程中也对此进行了讨论。【参考方案2】:使用 typeof element === "string" 而不是 instanceof。 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/instanceof instanceof 不适用于原始数据类型。
【讨论】:
以上是关于typeof string 怎么不是 instanceof String 呢? [复制]的主要内容,如果未能解决你的问题,请参考以下文章