我在哪里做错了?
由于这段代码,我会等待“Class”,但它不会:
这是来自对象函数:
Tyepof 不是这样工作的,它只返回内置类型。你可以试试:
this.constructor.name==="Class";
它将一直检查原型链以查看是否this
或任何原型this
是 Class。因此,如果OtherType.prototype=Object.create(Class);
那样的话,对于任何 OtherType 实例都是如此。不适用于 < IE9
或者
this instanceof Class
但这不会检查整个原型链。
这是 typeof 可以返回的返回值列表
这是一个关于获取变量类型的答案,该变量具有更多详细信息并显示了它可以破坏的多种方式。
object.constructor.name
将返回构造函数的名称。这是一个例子:
function SomeClass() {
/* code */
}
var obj = new SomeClass();
// obj.constructor.name == "SomeClass"
请注意,您需要使用命名函数,如果将匿名函数分配给变量,它将是一个空字符串...
var SomeClass = function () {
/* code */
};
var obj = new SomeClass();
// obj.constructor.name == ""
但是你可以同时使用两者,那么命名函数的名称将被返回
var SomeClassCtor = function SomeClass() {
/* code */
};
var obj = new SomeClassCtor();
// obj.constructor.name == "SomeClass"
你也可以试试这个
function getType(obj){
if (obj === undefined) { return 'undefined'; }
if (obj === null) { return 'null'; }
return obj.constructor.name || Object.prototype.toString.call(obj).split(' ').pop().split(']').shift().toLowerCase();
}
function MyClass(){}
console.log(getType(new MyClass)); // MyClass
console.log(getType([])); // Array
console.log(getType({})); // Object
console.log(getType(new Array)); // Array
console.log(getType(new Object)); // Object
console.log(getType(new Date)); // Date
console.log(getType(new Error)); // Error