原型对象的获取和设置补充
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<script>
function Person(name, age) {
this.name = name;
this.age = age;
}
Person.prototype.showName = function() {
console.log("姓名:" + this.name);
}
var p = new Person();
/* 01-原型对象的访问(获取) */
/* 01-[1] 构造函数.prototype */
console.log(Person.prototype);
/* 01-[2] 实例对象.__proto__ */
console.log(p.__proto__);
/* 01-[3] Object.getPrototypeOf(实例对象)*/
console.log(Object.getPrototypeOf(p));
console.log(Person.prototype === p.__proto__, p.__proto__ === Object.getPrototypeOf(p));
/* 02-原型对象的设置 */
// Person.prototype.showAge = function(){}
// Person.prototype = {constructor:Person};
p.__proto__.showAge = function() {};
Object.getPrototypeOf(p).showInfo = function() {};
console.log(p);
/* 补充方法 */
var obj = {
className: "1906"
}
/* 设置obj这个对象的原型对象为Person.prototype 类似于Object.create() */
Object.setPrototypeOf(obj, Person.prototype);
console.log(obj);
</script>
</body>
</html>
isPrototypeOf和instanceof比较
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<script>
/*01- isPrototypeOf() 检查当前对象是否是指定对象的原型对象*/
function Person(name, age) {
this.name = name;
this.age = age;
}
Person.prototype.showName = function() {
console.log("姓名:" + this.name);
}
var p = new Person();
/* 检查Person.prototype是否是p这个实例对象的原型对象 */
console.log(Person.prototype.isPrototypeOf(p));
console.log(Array.prototype.isPrototypeOf(p));
/* 02-instanceof 具体准确:检查指定构造函数的原型对象是否在当前对象的原型链上面*/
// console.log(p instanceof Array);
Person.prototype = {};
console.log("____");
console.log(p instanceof Person); //true
console.log(p instanceof Function); //false
console.log(p instanceof Object); //true
</script>
</body>
</html>