js 高级 constructor构造函数

本文探讨了JavaScript中对象原型(__proto__)和构造函数(prototype)的使用,重点讲解了constructor属性的作用以及如何正确地修改原型对象。实例演示了原型链的工作原理,并强调了当修改原型对象时手动设置constructor的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

对象原型(__proto__)和构造函数(prototype)原型对象里面都有一个属性 constructor 属性,它指回构造l类本身.

 function Person(uname, age) {
     this.uname = uname;
     this.sing = function() {
     console.log('我会唱歌');
    }
}
var person1 = new Person('wang', 18);
var person2 = new Person('wei', 18);
person1.sing();//我会唱歌
person2.sing();//我会唱歌

在这里插入图片描述

当我们直接给prototype直接赋值时,要手动添加constructor

 function Person(uname, age) {
     this.uname = uname;
     this.sing = function() {
     console.log('我会唱歌');
    }
}
// Person.prototype.sing = function() {//向prototype中追加一个变量,不需要考虑`constructor`,因为本身带有
//    console.log('我会唱歌');
//}


Person.prototype = {
 // 如果我们修改了原来的原型对象,给原型对象赋值的是一个对象,则必须手动的利用constructor指回原来的构造函数
   constructor: Star, // 手动设置指回原来的构造函数
   sing: function() {
     console.log('我会唱歌');
   }
}

var person1 = new Person('wang', 18);

//两个方法的sing都是调用prototype.sing
person1.sing();//我会唱歌
person2.sing();//我会唱歌
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值