1.如何区分formdata与普通object
可以使用 instanceof 运算符来判断
let test1 = new FormData()
console.log(test1 instanceof FormData)
//结果 = true
2.instanceof 运算符描述
Dosen’t ‘a’ in stance of ‘b’? 感兴趣可以翻译一下这个句子
instanceof 运算符用来检测参数a的 constructor.prototype 是否存在于参数 b 的原型链上。
注意参数的prototype属性的值是有可能改变的,根据结果,instanceof返回的值也不一定一直是true或false
3.这里引用一下MDN的测试
// 定义构造函数
function C(){}
function D(){}
var o = new C();
o instanceof C; // true,因为 Object.getPrototypeOf(o) === C.prototype
o instanceof D; // false,因为 D.prototype 不在 o 的原型链上
o instanceof Object; // true,因为 Object.prototype.isPrototypeOf(o) 返回 true
C.prototype instanceof Object // true,同上
C.prototype = {};
var o2 = new C();
o2 instanceof C; // true
o instanceof C; // false,C.prototype 指向了一个空对象,这个空对象不在 o 的原型链上.
D.prototype = new C(); // 继承
var o3 = new D();
o3 instanceof D; // true
o3 instanceof C; // true 因为 C.prototype 现在在 o3 的原型链上
本文深入探讨了instanceof运算符的使用,详细解释了如何通过该运算符检测对象的原型链,包括其工作原理及在JavaScript中判断对象类型的具体应用。同时,提供了实例代码展示不同情况下instanceof的返回结果。
1826

被折叠的 条评论
为什么被折叠?



