new构造函数和原型链

本文探讨了JavaScript中的构造函数与原型链概念。当一个函数被new关键字调用时,它成为构造函数,否则则不是。通过检查某个对象的prototype属性,可以判断其是否由构造函数创建。JS是一种基于对象的语言,而非面向对象,原型链prototype在其中起着关键作用,每个构造函数都有prototype属性,指向一个空对象。

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

new构造函数
function People(name,age) {
    this.name=name;
    this.age=age;
}

这个函数是不是构造函数?他没有被调用,用new调用后就是构造函数,不被new调用就不是构造函数

function People(name,age) {
    this.name=name;
    this.age=age;
}
var  obj = People("小明",12);
alert(obj==null);
alert(obj.age);


看到这个结果为null,我们就可以知道,这个函数不被调用,因为没有用new调用函数,所以声明的obj对象就是null

JS不是面向对象(oop)的,而是基于对象(bop)得到语言;

原型链prototype

每一个构造函数都有prototype属性,指向一个空对象


function People(name,age,sex) {
    this.name=name;
    this.age=age;
    this.sex=sex;
}
People.prototype={
    "teacher":"考拉",
    "IQ":180,
    "salary":30000
}
var xiaoming=new People();
var xiaohong=new People();
var xiaogang= new People();

alert(xiaoming.teacher);
alert(xiaohong.teacher);
alert(xiaogang.IQ);
最后显示的结果是:考拉,考拉180;这说明了即使构造的子集中没有调取的属性,还可以顺着原型链找父类中的属性


//构造函数
function People(name,age,sex) {
    this.name=name;
    this.age=age;
    this.sex=sex;
}
//更改构造函数的prototypePeople.prototype=Math;

var xiaoming= new People("小明",12,"");
//小明身上虽然没有random属性,但是小明的_proto_身上有这个属性
//所以小明能够大点调用random属性;
alert(xiaoming.random());

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值