首页 > 作文

JavaScript原型与实例详解

更新时间:2023-04-04 11:40:30 阅读: 评论:0

构造函数 实例 原型三者的关系

1.任何函数都有一个prototype属性,该属性是一个对象

function f () {}console.log(f.prototype) 左成语// => object//原型对象f.prototype.sayhi = function () {  console.log('hi!')}

2.构造函数的prototype对象默认都有一个constructor属性,指向prototype对象所在函数

console.log(f.constructor === f) // => true//表示这个

3.通过构造函数得到的实例对象内部会包含一个指向构造函数的prototype对象的指针_proto_

var instance = new f()console.log(instance.__proto__ === f.prototype) // => true

意思是用当前构造函数创建的实例对象内部都包含一个指针,这个指针就是_proto_,然后这个指针是指向构造函数的prototype对象的

因此我们可以直接用实例访问原型对象上的成员

例:

instance.sayhi() // => 打印hi!

注意

_proto_是一个非标准属性

prototype属性

javascript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象。
这个对象的所有属性和方法,都会被构造函数的实例继承。

这也就意味着,我们可以把所有对象实例需要共享的香囊属性和方法直接定义在prototype对象上。

例子:

function 微笑的味道person (name, age) {  this.name = name  this.age = age}console.log(person.prototype)//打印原型person.prototype.type = 'human'//将human挂载到原型对象的属性上person.prototype.sayname = function () {//还可以定义函数  console.log(this.name)}let p1 = new person(...)let p2 = new p单片机论文erson(...)co雷锋名言警句nsole.log(p1.sayname === p2.sayname) // => true

我们可以看到console.log(p1.sayname === p2.sayname)这行代码打印的结果是true

这是因为所有实例的type属性和sayname()方法都是一个同一个内存地址,都是指向prototype对象,因此提高了运行效率

属性或成员的搜索原则

我们知道了多个实例对象是可以共享原型对象中的属性或成员的,那么js中是怎么实现这个共享机制的呢?

这就不得不提到属性的搜索原则了

每当代码读取某个实例对象的某个属性时,都会执行一次搜索,搜索目标是具有给定名字的属性或者成员

搜索过程如下:

1.首先从对象实例本身开始搜索

2.如果在实例对象中找到了具有给定名字的属性,则返回该属性的值

3.如果没有找到,则继续搜索实例对象中含有的指针(上文中讲过)指向的原型对象,在原型对象中查找具有给定名字的属性

4.如果在原型对象中找到了这个属性,则返回该属性的值

在执行instance.sayname()时,会执行两次搜索,第一次搜索实例对象,第二次搜索原型对象

总结

以上就是多个实例对象共享原型所挂载的属性和方法的基本原理!

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注www.887551.com的更多内容!

本文发布于:2023-04-04 11:40:29,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/b634599f4411c51e327a099c00d55d8b.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:JavaScript原型与实例详解.doc

本文 PDF 下载地址:JavaScript原型与实例详解.pdf

标签:对象   属性   原型   实例
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图