关于prototype属性的理解
2024-08-20 23:47:18
众所周知,prototype是一个属性对象,只要创建一个新函数,就会根据特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象。在默认情况下,所有原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含一个指向prototype属性所在函数的指针。
需要注意的是,prototype是一个对象,他具体的内部结构是这样的:
//创建一个原型对象
function Foo(){};
console.log(typeof Foo.prototype); // 'object'
Foo.prototype.x=1;
Foo.prototype.show=function(){
alert(this.name);
}
//则其内部结构
Foo.prototype
{
constructor:Foo,
_proto_:Object.prototype,
show:function()...
x:1;
}
根据其内部结构我们再来看最上面的一句话,每个由原型对象创建的对象实例,都会有一个prototype属性,其指向原型对象的prototype属性。原型对象都会自动获得一个constructor属性,这个属性包含一个指向prototype属性所在函数的指针,即在这里的 Foo.prototype.constructor指向Foo.
接下来我们在定义这样一段代码
var foo=new Foo();
foo.name="小明";
当调用构造函数创建一个示例之后,该实例的内部将包含一个指针(内部属性__protot__),它将指向构造函数的原型对象,这里就是Foo.prototype
这里,之所以foo对象实例能够调用show()方法的原因就是:js引擎在foo对象中没有找到show()方法,便通过其_proto_属性向上找到Foo.prototype属性里面的show()方法,来完成调用。
最新文章
- console的高级使用
- .Net语言 APP开发平台——Smobiler学习日志:快速实现手机上的图片上传功能
- Go语言http包Form解析之坑
- 【转】总结:2015这一年App Store审核指南都有哪些变化
- 产品需求文档(PRD)的写作方法之笔记一
- mybatis Generator配置文件详解
- JQ库函数记忆要点
- javascript 中的 true 或 false
- 自动布局之autoresizingMask
- 2015年百度之星初赛(1) --- C 序列变换
- Apache Commons fileUpload实现文件上传之一
- winsock开发重复定义问题
- alex python of day2
- ora-01190和ora-01110的解决方法
- Qt4.8.6开发WinCE 5.0环境搭建
- 在 sql server 中,查询 数据库的大小 和 数据库中各表的大小
- Learning-Python【32】:进程理论基础
- RGB颜色对照表
- Leetcode 980. 不同路径 III
- ArcGIS案例学习笔记3_1_ArcMap编辑练习