基于JavaScript实现的继承机制之原型链(prototype)的实现教程
程序员文章站
2022-04-01 13:14:42
__proto__是每个对象都有的一个属性,而prototype是函数才会有的属性!!!
使用Object.getPrototypeOf()代替__proto__!!!
一、p...
__proto__是每个对象都有的一个属性,而prototype是函数才会有的属性!!!
使用Object.getPrototypeOf()代替__proto__!!!
一、prototype
几乎所有的函数(除了一些内建函数)都有一个名为prototype(原型)的属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以有特定类型的所有实例共享的属性和方法。prototype是通过调用构造函数而创建的那个对象实例的原型对象。hasOwnProperty()判断指定属性是否为自有属性;in操作符对原型属性和自有属性都返回true。
示例:自有属性&原型属性
var obj = {a: 1}; obj.hasOwnProperty("a"); // true obj.hasOwnProperty("toString"); // false "a" in obj; // true "toString" in obj; // true
示例:鉴别原型属性
function hasPrototypeProperty(obj, name){ return name in obj && !obj.hasOwnProperty(name); }
二、__proto__
对象具有属性__proto__,可称为隐式原型,一个对象的隐式原型指向构造该对象的构造函数的原型,这也保证了实例能够访问在构造函数原型中定义的属性和方法。
function Foo(){} var Boo = {name: "Boo"}; Foo.prototype = Boo; var f = new Foo(); console.log(f.__proto__ === Foo.prototype); // true console.log(f.__proto__ === Boo); // true Object.getPrototypeOf(f) === f.__proto__; // true
上一篇: 调用接口时怎么将一台实例移出指定的安全组
下一篇: 不是说只逛逛吗
推荐阅读
-
JavaScript使用prototype原型实现的封装继承多态示例
-
JavaScript使用原型和原型链实现对象继承的方法详解
-
基于JavaScript实现的继承机制之原型链(prototype)的实现教程
-
JavaScript使用prototype原型实现的封装继承多态示例
-
JavaScript使用原型和原型链实现对象继承的方法详解
-
基于JavaScript实现继承机制之调用call()与apply()的方法详解_基础知识
-
javascript中通过原型链实现继承的解析(附代码)
-
基于JavaScript实现继承机制之构造函数方法对象冒充的使用详解_基础知识
-
JavaScript面向对象-基于原型链和函数伪装组合的方式实现继承
-
基于JavaScript实现继承机制之调用call()与apply()的方法详解_基础知识