JS学习记录(1) 怎么理解原型和原型链(2021-10-15)

本文深入探讨了JavaScript中的原型和原型链概念。通过示例展示了如何在构造函数中创建对象,并在原型上添加方法。还阐述了如何使用`Object.create()`创建对象并理解对象间的继承关系。此外,文章解释了`hasOwnProperty()`方法的作用,用于判断对象是否包含特定的自身属性,而非继承的属性。最后,通过示例说明了`in`操作符和`hasOwnProperty()`的区别。
摘要由CSDN通过智能技术生成
一、原型和原型链
//原型对象
//在Person这个类的全局对象中添加一个函数,然后在类中引用

//通过构造函数来创建对象
function Person(name,age){
    //设置对象的属性
    this.name = name ;
    this.age = age ;
}

//在Person类的原型对象中添加方法
Person_n.prototype.sayName = function(){
    console.log("原型 " + this.name);
};

var person_n1 =new Person("P1",18);
person_n1.sayName();

//赋值
var A = {
    a:1,
    b:2
};
    
//A{a:1,b:2}
var B = Object.create(A);
var C = Object.create(B);
//A{a:1,b:2},B{A{a:1,b:2}},C{B{A{a:1,b:2}}}
            
B.c = 3;
C.d = 4;
//A{a:1,b:2},B{A{a:1,b:2},c=3},C{B{A{a:1,b:2},c=3},d=4}

console.log(C);   //输出:{d:4}
            
for(var key in C){
    console.log(C[key]);
};

//会在控制台中依次打印出4 3 1 2(C→B→A逐级查找)

结果:
在这里插入图片描述

二、hasOwnProperty方法判断对象是否包含特定的自身(非继承)属性
//2.12.6hasOwnProperty方法

//创造一个构造函数
function MyClass(){
}
//向MyClass的原型中方你添加一个name属性
MyClass.prototype.name="原型的名字";

//创建一个MyClass的实例
var mc = new MyClass();
mc.age=19;

//使用in检查对象中是否含有某个属性时,如果对象中没有但原型中有,也会返回true
console.log("age" in mc); //true
console.log("name" in mc); //true

//若只检查自身对象是否含有某个方法或属性 Object的hasOwnProperty()
console.log(mc.hasOwnProperty("age")); //true
console.log(mc.hasOwnProperty("name")); //false

//检查当前对象
console.log(mc.hasOwnProperty("hasOwnProperty")); //false
//检查当前对象的原型对象
console.log(mc.__proto__.hasOwnProperty("hasOwnProperty")); //false
//检查当前对象的原型对象的原型对象
console.log(mc.__proto__.__proto__.hasOwnProperty("hasOwnProperty")); //true

参考:
1.理解原型与原型链

2.帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值