JavaScript - 理解原型

Function对象特有的属性 prototype

所有对象都有的属性 __proto__

1、用法

const F = function (name) {
  this.name = name
}
F.prototype.greeting = function () {
  console.log(‘hello‘, this.name)
}

let f1 = new F(‘osyo‘)
let f2 = new F(‘mioco‘)

f1.greeting() // hello osyo
f2.greeting() // hello mioco

可以看出,prototype主要用来放共有的属性和方法,这样你就不用每次new的时候都实例化那个属性了。

2、prototype和__proto__的关系

方法对象都有这两个属性,prototype是该方法的原型,__proto__是它父亲的原型(Object作为生命的起源它的__proto__为null)

3、应用举例

1) underscore.js代码节选

  // Save bytes in the minified (but not gzipped) version:
  var ArrayProto = Array.prototype, ObjProto = Object.prototype;
  var SymbolProto = typeof Symbol !== ‘undefined‘ ? Symbol.prototype : null;

  // Create quick reference variables for speed access to core prototypes.
  var push = ArrayProto.push,
      slice = ArrayProto.slice,
      toString = ObjProto.toString,
      hasOwnProperty = ObjProto.hasOwnProperty;

underscore在这里把原生对象的原型保存在变量中以加快访问速度,因为原型链的索引是当前对象->对象原型->父亲的原型->...->Object原型,顺着链子往上找还是挺耗时的大约...(话说这个例子感觉用来举例原型链比较合适的样子...)

2) classes polyfill

我们知道ES6中新增了一个语法糖Class

ES6:

class F {
  constructor (name) {
    this.name = name
  }
  greet () {
    console.log(‘hello ‘ + this.name)
  }
}

class SubF extends F{
  constructor () {
    super(‘osyo from subF‘)
  }
  subGreet () {
    super.greet()
  }
}

let f = new SubF()
f.subGreet() //hello osyo from subF

等价于ES5:

function F (name) {
  this.name = name
}
F5.prototype.greet = function () {
  console.log(‘hello ‘ + this.name)
}
F5.greetAll = function () {
  console.log(‘hello everybody‘)
}

function SubF () {
  F.call(this, ‘osyo from subF‘)
}
// 继承属性
SubF.prototype = Object.create(F.prototype)
SubF.prototype.contructor = F
SubF.greetAll = F.greetAll

//子类方法的属性
SubF.prototype.subGreet = function () {
  F5.prototype.greet.call(this)
}
let f = new SubF5()
f.subGreet() //hello osyo from subF
时间: 2024-11-10 20:18:13

JavaScript - 理解原型的相关文章

node.js javascript理解原型继承

util.inherits util.inherits(constructor, superConstructor)是一个实现对象间原型继承的函数. JavaScript 的面向对象特性是基于原型的,与常见的基于类的不同.JavaScript 没有提供对象继承的语言级别特性,而是通过原型复制来实现的 var util = require('util'); function Base() { this.name = 'base'; this.base = 1991; this.sayHello =

深入理解javascript之原型

理解原型 原型是一个对象,其他对象可以通过它实现属性继承.任何一个对象都可以成为继承,所有对象在默认的情况下都有一个原型,因为原型本身也是对象,所以每个原型自身又有一个原型.任何一个对象都有一个prototype的属性,记为:__proto__.每当我们定义一个对象,其__proto__属性就指向了其prototype.示例如下: var foo = { x: 10, y: 20 }; 即使我们不指定prototype,该属性也会预留.如果我们有明确指向的话,那么链表就连起来了.需要注意的是,p

深刻理解JavaScript基于原型的面向对象

主题一.原型 一.基于原型的语言的特点 1 只有对象,没有类;对象继承对象,而不是类继承类. 2  "原型对象"是基于原型语言的核心概念.原型对象是新对象的模板,它将自身的属性共享给新对象.一个对象不但可以享有自己创建时和运行时定义的属性,而且可以享有原型对象的属性. 3 除了语言原生的顶级对象,每一个对象都有自己的原型对象,所有对象构成一个树状的层级系统.root节点的顶层对象是一个语言原生的对象,其他所有对象都直接或间接继承它的属性. 显然,基于原型的语言比基于类的语言简单得多,我

对Javascript的原型,原型链和继承的个人理解

继承是OO语言中一个最为人津津乐道的概念,也是初接触Javascript的初学者难理解的概念=.=继承主要分为两种:一种是接口继承,另一种是实现继承.而在ECMAScript中只支持实现继承,所以我们今天来讨论讨论实现继承.实现继承就是继承实际的方法,主要依靠原型链来实现.讲到这里我们就需要讨论讨论什么是原型链. 1.什么是原型 要理解原型链我们首先要知道什么是原型.我们知道每个函数都有一个prototype属性,这个属性是一个指针,指向一个对象,这个对象包含所有实例共享的属性和方法.所以我个人

理解JavaScript 的原型属性

1.原型继承 面向对象编程可以通过很多途径实现.其他的语言,比如 Java,使用基于类的模型实现: 类及对象实例区别对待.但在 JavaScript 中没有类的概念,取而代之的是一切皆对象.JavaScript 中的继承通过原型继承实现:一个对象直接从另一对象继承.对象中包含其继承体系中祖先的引用——对象的 prototype 属性. 2. JavaScript 实现继承的语言特性 当尝试访问 JavaScript 对象中不存在的属性时,解析器会查找匹配的对象原型.例如调用 car.toStri

第一篇 对Javascript中原型的深入理解

  理解原型对象 在Javascript中不管什么时候,仅仅要创建一个新的函数,就会依据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象(这个对象的用途是包括能够有特定类型的全部实例共享的属性和方法).假设依照字面上的意思来理解.那么原型属性就是通过调用构造函数而创建的那个对象的实例的原型对象. 在默认的情况下,全部的原型对象都会自己主动获得一个constructor(构造函数)属性,这个属性包括一个指向prototype属性所在函数的指针. 例如以下图 func

javascript 之原型理解

最近一直在了解javascript原型的问题,也算是理解了一点,希望把我所理解的,用简单的例子和说明,让更多人清除的去理解javascript原型 1,原型 prototype 是一个什么东西 我们创建的每一个函数都有一个prototype属性,这个属性是一个指针,指向一个对象.简单的说 prototype就是一个对象 理解原型对象: 无论什么时候只要创建了一个新函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象. 创建自定义的构造函数后,原型对象默认

对Javascript中原型的深入理解

  理解原型对象 在Javascript中无论什么时候,只要创建一个新的函数,就会根据一组特定的规则为该函数创建一个prototype属性,这个属性指向函数的原型对象(这个对象的用途是包含可以有特定类型的所有实例共享的属性和方法).如果按照字面上的意思来理解,那么原型属性就是通过调用构造函数而创建的那个对象的实例的原型对象. 在默认的情况下,所有的原型对象都会自动获得一个constructor(构造函数)属性,这个属性包含一个指向prototype属性所在函数的指针.如下图 function P

理解Javascript的原型链

要理解原型链,首先要清楚理解以下几点: 1.所有函数都事Function的实例化,都包含prototype属性,即原型对象. 2.所有对象都有__proto__属性,该属性指向对象构造函数的prototype原型对象. 3.prototype原型对象的constructor属性指向它所在的构造函数,即构造函数本身. 4.prototype是针对函数说的,__proto__是针对对象说的. 5.函数本身也是对象. 认识到以上几点,我们先看一下原型链: function setName() { th