js-函数的prototype


1、 函数的prototype属性

2、 给原型对象添加属性(一般都是方法)

3、 显式原型与隐式原型

1、 函数的prototype属性
每个 函数 都有一个prototype属性(是一个object类型数据),它默认指向一个object空对象(即称为:原型对象)
console.log(typeof Date.prototype) //object
console.log(Date.prototype) //如图1所示
function fun(){
}
console.log(fun.prototype) //默认指向一个object空对象(没有我们的属性)图1
图2
/* Date函数的流程基本就是 首先创建一个Date函数, 然后通过Date.prototype(指向原型对象)向Date函数原型对象中添加很多方法 如下:以函数fun为例 */
function fun(){
}
fun.prototype.test = function(){
}
console.log(fun.prototype)原型对象中有一个属性constructor,他指向函数对象
// 原型对象中有一个属性constructor,他指向函数对象
console.log(Date.prototype.constructor === Date) // true
console.log(fun.prototype.constructor === fun) // true2、 给原型对象添加属性(一般都是方法)
作用:函数的所有实例对象自动拥有原型中的属性(方法)
/* 给原型对象添加属性(一般都是方法)===》实例对象可以访问 */
function Fun(){
}
Fun.prototype.test = function(){
console.log('test()')
}
var fun = new Fun() // 实例化对象
fun.test() //test() 实例对象可以直接访问3、 显式原型与隐式原型
每个函数function都有一个prototype,即显式原型
每个实例对象都有一个__proto__,即隐式原型
对象的隐式原型的值为其对应的构造函数的显式原型的值
/* 每个**函数function**都有一个prototype,即显式原型,默认指向一个object空对象 */
function Fn(){
//内部语句:this.prototype = {}
}
console.log(Fn.prototype)
/* 每个**实例对象**都有一个__proto__,即隐式原型,默认指向一个object空对象 */
var fn = new Fn() // 实例化对象,内部语句:this.__proto__ = Fn.prototype
console.log(fn.__proto__)
/* 对象的隐式原型的值为其对应的构造函数的显式原型的值,引用地址值相同,指向同一个对象 */
console.log(Fn.prototype === fn.__proto__) //true
Fn.prototype.test = function(){
console.log('test()')
}
fn.test() // test() 对象可以直接访问自己__proto__里面的属性和方法,本质上 对象的__proto__与其构造函数的prototype 指向的是同一个对象内存结构
总结:
(1)对象的prototype属性:在定义函数时自动添加的,默认值是一个空object对象
(2)对象的__proto__属性:创建对象时自动添加的,默认值是构造函数的prototype属性值
(3)程序员可直接操作显式原型,但不能操作隐式原型(es6之前)
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/hz/137239.html