一篇文章读懂JS原型和原型链(js原型和原型链有什么特点)
myzbx 2025-06-18 23:01 38 浏览
前言
你好! 欢迎阅读本篇文章,今天我将要用一篇文章带你深入理解JavaScript中的原型和原型链,让我们一起揭开原型神秘的面试,一起窥探其中的奥妙。
一切皆是对象
看到这个标题你可能就有你可能就有疑问了,怎么这篇文章一开始就要胡扯了,然后准备要关闭这篇这篇文章。别急、客官,接下来就让我们仔细掰扯掰扯这句话
“一切皆是对象”是没错,关键在于你如何理解这个“对象”这个概念。这句话的重点也在于此。
在理解对象之前,我们先引用一个我们的老朋友 typeof ,相信很多前端的同学都应该知道这个JavaScript的常用运算符,如果你不知道,请仔细阅读下面文字。
我们都知道 typeof 可以判断一个变量的类型,返回值共有一下几种( undefined、number、string、boolean、function、object、Symbol )其中 Symbol 是 ES6 引入的新类型。
function test() {
var x;
console.log(typeof x) //undefined
console.log(typeof 100) //number
console.log(typeof 'typeof') //string
console.log(typeof true) //boolean
console.log(typeof [1,2,3,4]) //object
console.log(typeof {a:1,b:2}) //object
console.log(typeof null) //object null在这里为空对象(注意)
console.log(typeof new Number(100)) //object
console.log(typeof function(){}) //function
}上面代码列出的是 typeof 返回的几种值,其中代码前四种是值类型,余下的几种情况都是引用类型,他们也都是对象。关于引用类型和值类型的区别请看我们另一篇文章值类型和引用类型.
对象是若干属性的集合,对象里面的一切都是属性,都是以键值对的形式出现,其中方法也是一种特殊的属性。属性的值也能是一个对象(禁止套娃qAq)对象可以用instanceof判断,记住一切(应用类型)都是对象,对象是属性的集合,一切对象都是通过函数来创建的
原型知多少
说到原型我们就不得不说 prototype 我们知道每个函数都有一个 prototype (原型)属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以由特定类型的所有实例共享的属性和方法。我放了两张图片帮你理解(qwq)
上图SuperType是函数,他的原型就是SuperType Prototype,原型的constructor属性指向它的构造函数SuperType。
上图是对象的Object的以及它的原型,我们可以看到原型上有很多我们常用的属性和方法,应为一切对象的原型都直接或间接的指向了它,因此可以使用上面的方法。
上面说到每一个函数都有自己的prototype,也就是原型,那么通过 new 生成的函数实例呢?这里就不禁要疑问了,其实每个new出来的实例,以及每一个对象都有一个__proto__,即隐式原型。
上面图片显示了对象obj的__proto__属性,下面我再放一张Object的prototype。
从上面的截图看出,obj.proto__和Object.prototype是一样的
我们用一张图表示。
从图中我们得知每个对象都有都有一个__proto,并且指向该对象函数的prototype。
唯一的特例Object.prototype的__proto__指向的是null
还有就是,函数也是对象,函数也有一个__proto__,指向Function.prototype,函数是由Function创建出来的,而Function又被自身创建。
var foo = new Function("x","y","return x+y")就是这样,建议不要这样创建函数
原型链和继承
下面用一张详细的图,请仔细阅读,我们根据这张图讲解原型链
要说起原型链,我们不得不用到一个工具instanceof,对于引用类型,我们想要知道引用类型的具体是数组还是对象,就要用到这个工具。如下所示
function Foo(){}
var f1 = new Foo()
console.log(foo instanceof Foo) //true
console.log(foo instanceof Object) //true结合上图我们我们来看看,instanceof运算符的规则就是,实例foo沿着__proto__这条线,同时Foo沿着prototype这条线来找,如果这两条线找到了同一个对象,那么就返回true,否则就返回false, instanceof表示一种继承关系,或者原型链的结构
JavaScript是通过原型链的方式来实现继承的,又被称作为原型链对象继承,对于一个对象,它可以访问它原型对象的属性。同理,原型对象也是一个属性,它也有自己的原型,因此也可以继承它原型对象原型的属性。
访问一个对象的属性时,现在基本的对象内找,如果找不到,就沿着__proto__这条链向上找。
几种常见的继承方式
组合继承
组合继承(combination inheritance),有时候也叫做伪经典继承,指的是将原型链和借用构造函数的
技术组合到一块,从而发挥二者之长的一种继承模式。其背后的思路是使用原型链实现对原型属性和方
法的继承,而通过借用构造函数来实现对实例属性的继承。这样,既通过在原型上定义方法实现了函数
复用,又能够保证每个实例都有它自己的属性。下面来看一个例子
function SuperType(name){
this.name = name;
this.colors = ["red", "blue", "green"];
}
SuperType.prototype.sayName = function(){
alert(this.name);
};
function SubType(name, age){
//继承属性
SuperType.call(this, name);
this.age = age;
}
//继承方法
SubType.prototype = new SuperType();
SubType.prototype.constructor = SubType;
SubType.prototype.sayAge = function(){
alert(this.age);
};
var instance1 = new SubType("Nicholas", 29);
instance1.colors.push("black");
alert(instance1.colors); //"red,blue,green,black"
instance1.sayName(); //"Nicholas";
instance1.sayAge(); //29
var instance2 = new SubType("Greg", 27);
alert(instance2.colors); //"red,blue,green"
instance2.sayName(); //"Greg";
instance2.sayAge(); //27ES6中继承
ES6是通过class实现了类,通过extends实现了标准化继承,然而,class、extends本质上还是语法糖,通过bable可以将其转译为ES5代码执行。
ES6中的class、extends使用的是ES5中寄生组合继承,并对寄生组合继承作出了一下优化,如下所示
ES6中继承使用Object.create()以SuperClass的原型对象创建了一个新的原型对象,即SubClass.prototype.proto = SuperClass.prototype。 同时使其constructor属性指向SubClass。
ES5的继承是子类的原型对象__proto__属性指向父类的原型对象,而ES6中继承是子类__proto__指向父类。
写在最后
以上就是本人对原型和原型链的整理和记录,因为资料来源比较多,在整理和书写是难免出现错误,如果你看到这里,发现原文有错误的地方,或者有什么想要分享的,也欢迎在评论区留言,一起学习,加油,奥利给
相关推荐
- 如何设计一个优秀的电子商务产品详情页
-
加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...
- 怎么在JS中使用Ajax进行异步请求?
-
大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...
- 中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革
-
前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...
- 前端监控 SDK 开发分享_前端监控系统 开源
-
一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...
- Ajax 会被 fetch 取代吗?Axios 怎么办?
-
大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...
- 前端面试题《AJAX》_前端面试ajax考点汇总
-
1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...
- Ajax 详细介绍_ajax
-
1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...
- 6款可替代dreamweaver的工具_替代powerdesigner的工具
-
dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...
- 我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊
-
接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...
- 福斯《死侍》发布新剧照 "小贱贱"韦德被改造前造型曝光
-
时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...
- 2021年超详细的java学习路线总结—纯干货分享
-
本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...
- 不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!
-
Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...
- 2025 年 Python 爬虫四大前沿技术:从异步到 AI
-
作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...
- 最贱超级英雄《死侍》来了!_死侍超燃
-
死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...
- 停止javascript的ajax请求,取消axios请求,取消reactfetch请求
-
一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)
