为了账号安全,请及时绑定邮箱和手机立即绑定

JavaScript 原型

标签:
JavaScript

原型,是 JavaScript 语言中的非常重要的设计,它也是非常难以理解的,再加上原型一层嵌套一层,最终形成一个复杂的原型链,更佳让人琢磨不透。原型是一种对象创建型设计模式,通过克隆的方式来创建对象。

prototype

prototype并非对象的原型,它是构造函数的原型,也就是说只有function才有prototype属性。附着在prototype下的成员将原封不动的克隆到该类型对应的对象中,但是它并不会覆盖函数体内的同名方法。

var klass = function() {
    this.name = "jay";
    this.fn = function() {
        console.log("It's a function");
    }
}
klass.prototype.fn = function(){
    console.log("It's a prototype function");
};
klass.prototype.age = 4;
var obj = new klass();
console.log(obj.name + obj.age);
obj.fn();
//> Console:
//> jay4
//> It's a function

proto

在 JavaScript 中,所有的对象都有原型__proto__,它是不可操作。

var klass = function() {
    this.name = "jay";
}
var obj = new klass();
console.log(obj.__proto__);
console.log(obj.prototype);
//> Console:
//> Object {name: "jay"}
//> undefined

原型链

prototype__proto__ 的关系相当复杂,prototype为构造函数原型,__proto__为对象的原型,这样一来它两的指向是一致的。所有构造函数的__proto__都指向Function.prototype;Function.prototype的原型指向Object.prototype,而 Object.prototype的原型为空null,这样就构成了一条复杂的原型链。

var klass = function() {
    this.name = "jay";
}
var obj = new klass();
console.log(obj.__proto__ === klass.prototype);
console.log(klass.prototype.__proto__ === Object.prototype);
console.log(Object.prototype.__proto__ === null);
console.log(klass.constructor.__proto__ === Function.prototype);
console.log(Function.prototype.__proto__ === Object.prototype);
console.log(Object.prototype.__proto__ === null);
//> Console:
//> true
//> true
//> true
//> true
//> true
//> true

webp

js-prototype.png





点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
Web前端工程师
手记
粉丝
12
获赞与收藏
135

关注作者,订阅最新文章

阅读免费教程

  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消