"foo" instanceof String //=> false
"foo" instanceof Object //=> false

true instanceof Boolean //=> false
true instanceof Object //=> false
false instanceof Boolean //=> false
false instanceof Object //=> false

12.21 instanceof Number //=> false
/foo/ instanceof RegExp //=> true

// the tests against Object really don't make sense

数组字面量和对象字面量匹配…

[0,1] instanceof Array //=> true
{0:1} instanceof Object //=> true

为什么不是所有人?或者,为什么不都不呢? 那么,它们是什么实例呢?

在FF3、IE7、Opera和Chrome中也是如此。至少它是一致的。


当前回答

或者你可以像这样创建你自己的函数:

function isInstanceOf(obj, clazz){
  return (obj instanceof eval("("+clazz+")")) || (typeof obj == clazz.toLowerCase());
};

用法:

isInstanceOf('','String');
isInstanceOf(new String(), 'String');

这些都应该返回true。

其他回答

 typeof(text) === 'string' || text instanceof String; 

你可以用这个,这两种情况都适用

文本var = " foo ";// typeof将工作 String text= new String("foo");// instanceof将工作

我相信我已经想出了一个可行的解决方案:

Object.getPrototypeOf('test') === String.prototype    //true
Object.getPrototypeOf(1) === String.prototype         //false

或者你可以像这样创建你自己的函数:

function isInstanceOf(obj, clazz){
  return (obj instanceof eval("("+clazz+")")) || (typeof obj == clazz.toLowerCase());
};

用法:

isInstanceOf('','String');
isInstanceOf(new String(), 'String');

这些都应该返回true。

对我造成的困惑

"str".__proto__ // #1
=> String

所以"str" istanceof String应该返回true,因为istanceof的工作原理如下:

"str".__proto__ == String.prototype // #2
=> true

表达式#1和#2的结果相互冲突,因此应该有一个是错误的。

第一条是错的

我发现它是由__proto__非标准属性引起的,所以使用标准属性:Object.getPrototypeOf

Object.getPrototypeOf("str") // #3
=> TypeError: Object.getPrototypeOf called on non-object

现在表达式2和表达式3之间没有混淆了

你可以使用构造函数属性:

'foo'.constructor == String // returns true
true.constructor == Boolean // returns true