`

javascript之function的prototype对象

阅读更多
JS中的phototype是JS中比较难理解的一个部分

一、知识点

本文基于下面几个知识点:

1. 原型法设计模式
      原型法的主要思想是:
      现在有一个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展。
      我们称B的原型为A。

2. javascript的方法可以分为三类:
    1) 类方法
    2) 对象方法
    3) 原型方法

例子:
function People(name){
    this.name=name;
    //对象方法
    this.Introduce=function(){
        console.log("My name is "+this.name);
    }
}
//类方法
People.Run=function(){
    console.log("I can run");
}
//原型方法
People.prototype.IntroduceChinese=function(){
    console.log("我的名字是"+this.name);
} 

//测试
var p1=new People("Windking");
p1.Introduce();
People.Run();
p1.IntroduceChinese();




二、正式开始

1、prototype是什么含义?

Javascript中的每个对象都有prototype属性。
Javascript中对象的prototype属性的解释是:返回 “对象原型” 的引用。


2、什么是函数的“对象原型”(prototype)?

Function.prototype 属性可以被使用 new 关键字创建的 Function 的实例所继承。
Function.prototype 属性不能被删除。


prototype 不应与继承混淆:

A.prototype = new B();

A 的 prototype 为 B 的一个实例,可以理解A将B中的方法和属性全部克隆了一遍。
A 能使用 B 的方法和属性,这里强调的是克隆而不是继承。

可以出现这种情况:
A 的prototype是 B 的实例,同时 B 的prototype也是 A 的实例。

例子:
function Base(){
    this.showMsg = function(){.
         console.log("Base::showMsg");
    }
}

function Extended(){}

Extended.prototype = new Base();
var instance = new Extended();
instance.showMsg(); // 显示 Base::showMsg


首先定义 Base 类。
然后定义 Extended,以 Base 的一个实例作为 Extended 的函数原型。


那么就会有一个问题,如果extendClass中本身包含有一个与baseClass的方法同名的方法会怎么样?

下面是扩展实验2:
function Base(){
    this.showMsg = function(){
        console.log("Base::showMsg");
    }
}

function Extended(){
    this.showMsg =function (){
        console.log("Extended::showMsg");
    }
}

Extended.prototype = new Base();
var instance = new Extended();
instance.showMsg();  //显示:Extended::showMsg


实验证明:函数运行时会先去本体的函数中去找,如果找到则运行。找不到则去prototype中寻找函数。


那么又会有一个新的问题:
如果我想使用 Extended 的一个实例 instance 调用 Base 的方法showMsg怎么办?

答案是可以使用 call:
Extended.prototype = new Base();
var extend = new Extended();

var base = new Base();
base.showMsg.call(extend); //显示:Base::showMsg



下面这个代码如果理解清晰,那么对“类方法、原型方法、对象方法”就已经理解了:

//
//Base
function Base(name){  
    this.name = name || "BASE";

    this.showMsg = function(){  
        console.log(this.name, "::showMsg");
    }     
    this.baseShowMsg = function(){  
        console.log(this.name, "::baseShowMsg");
    }  
}  

Base.showMsg = function(){
    console.log(this.name, "::showMsg static");
}
Base.prototype.protoShowMsg = function(){
    console.log(this.name, "::protoShowMsg");
}

//
//Extended  
function Extended(name){
    this.name = name || "Extended";
    
    this.showMsg =function (){  
        console.log(this.name, "::showMsg");
    }  
}  

Extended.showMsg = function(){
    console.log(this.name, "::showMsg static");
}  

Extended.prototype = new Base();


//Test
var base= new Base(); 
var extended = new Extended();

extended.showMsg();          //显示: Extended ::showMsg
extended.baseShowMsg();      //显示: Extended ::baseShowMsg
extended.protoShowMsg();     //显示: Extended ::protoShowMsg

Base.showMsg.call(extended); //显示: Extended ::showMsg static 
base.showMsg.call(extended); //显示: Extended ::showMsg

//


函数的 prototype 对象,是一个普通的对象。
函数的 prototype 对象,不是函数对象,不具有函数对象的 prototype 属性。


三、面向对象编程:prototype 中的 function 与 this

prototype 既然是用来共享于函数的实例之间,
那么在 prototype 的 function 类型中使用 this 是面向对象编程不可缺少的实现。
因为 this 总是指向 function 的不同实例。但是可以只写一次 this。

//

var Person = function(name) {
  this.name = name;
};

Person.prototype.getName = function() {
  // use "this" in prototype.
  return this.name;
};



//test

var john = new Person("John");
console.log(john.getName());     // John

var Tomi = new Person("Tomi");
console.log(Tomi.getName());     // Tomi












—————————————

javascript 函数基础系列文章

1、JavaScript之变量的作用域
2、javascript之变量类型与变量声明及函数变量的运行机制
3、javaScript之function定义
4、javascript之function的prototype对象
5、javascript之function的(closure)闭包特性
6、javascript之function的this   
7、javascript之function的apply(), call()



___________


javascript 面向对象编程系列文章:

    1、javaScript之面向对象编程
    2、javascript之面向对象编程之属性继承
    3、javascript之面向对象编程之原型继承 
   

-



转载请注明,
原文出处:http://lixh1986.iteye.com/blog/1896682










--
引用地址:
http://www.cnblogs.com/yjf512/archive/2011/06/03/2071914.html




-












分享到:
评论

相关推荐

    JavaScript的prototype

    JavaScript中的`prototype`是一个核心概念,它涉及到对象继承和函数原型。在JavaScript中,每创建一个函数,该函数就会自动获得一个名为`prototype`的属性,这个属性是一个对象,用于实现对象间的继承。同时,每个...

    JavaScript使用prototype定义对象类型

    JavaScript 使用 prototype 定义对象类型 在 JavaScript 中,prototype 是一个非常重要的概念,它提供了一套面向对象编程的基础设施,允许开发者定义对象类型和实现继承。下面我们将详细介绍如何使用 prototype ...

    javascript Prototype 对象扩展.docx

    ### JavaScript Prototype 对象扩展 #### 一、简介与背景 在JavaScript中,`prototype`是一个非常重要的概念,尤其是在面向对象编程(OOP)方面。通过利用`prototype`,开发者能够更高效地管理对象间的共享属性和...

    了解JavaScript中的prototype (实例)

    JavaScript中的`prototype`是理解面向对象编程的关键概念之一。它是一种机制,允许对象共享属性和方法,从而实现代码复用。在JavaScript中,每个函数(包括构造函数)都有一个内置的`prototype`属性,这个属性指向一...

    javascript类库prototype.js

    6. **Class与Object继承**:Prototype.js 引入了面向对象的概念,实现了类(Class)和对象继承,使得JavaScript具备了更接近传统面向对象语言的编程模式。 7. **JSON支持**:随着JSON成为数据交换的主流格式,...

    Prototype_1.6 JavaScript代码和中文帮助手册

     每个函数就是一个对象(Function),函数对象都有一个子对象 prototype对象,类是以函数的形式来定义的。prototype表示该函数的原型,也表示一个类的成员的集合。  在通过new创建一个类的实例对象的时候,...

    JavaScript_Prototype(源代码+中文手册).rar

    2. **构造函数、原型与实例**:构造函数(如`Function`、`Object`等)用于创建新的对象,每个构造函数都有一个`prototype`属性,这个属性是一个对象,用于存储共享的方法和属性。当我们使用`new`关键字创建新对象时...

    Javascript 面向对象的JavaScript进阶

    ### JavaScript面向对象进阶知识点详解 #### 8.1 面向对象编程的基本特性 在探讨面向对象的JavaScript之前,我们首先需要了解面向对象编程(Object-Oriented Programming, OOP)的基本特性:封装性、抽象性、继承...

    Javascript面向对象编程.

    在提供的资源中,《代码之美》PDF文件可能包含了关于编程实践和代码风格的指导,而《Javascript面向对象编程》PPT可能更具体地阐述了JavaScript OOP的细节和示例。学习这些材料将有助于深入理解JavaScript的面向对象...

    JavaScript中的prototype(原型)属性研究

    JavaScript中的prototype属性是理解面向对象编程的关键概念之一。在JavaScript中,每个函数都有一个prototype属性,这个属性指向一个对象,这个对象就是所谓的原型对象。当我们创建一个函数实例时,实例会自动获取一...

    JavaScript中的prototype原型学习指南

    原型是什么 Function 类型有一个属性 prototype,直接翻译过来就是原型。这个属性就是一个指针,指向一个对象,这个...先创建了一个 Function 类型的实例 person,然后 person 的方法 prototype 是一个对象,就声明指

    jQuery、Mootools、Prototype三大JavaScript框架中文手册

    Prototype是最早的JavaScript框架之一,对DOM操作有着深入的优化。其关键特性包括: 1. **$()选择器**:Prototype使用`$()`作为基本选择器,类似于jQuery,但功能略有不同。 2. **Prototype对象**:扩展了...

    Javascript面向对象编程

    利用`function`作为类的定义、`new`操作符创建对象、以及`this`和`prototype`来模拟类的特性和行为,可以有效地提高代码的可读性和可维护性。通过深入理解这些概念,开发者可以更好地利用JavaScript的强大功能来构建...

    JAVASCRIPT 面向对象编程精要

    ### JavaScript面向对象...JavaScript的独特之处在于它的灵活性和动态性,这使得它成为了一种非常强大的工具,适用于各种不同的应用场景。随着ES6及更高版本标准的引入,JavaScript的面向对象能力得到了进一步增强。

    JavaScript核心对象参考手册

    2. **对象创建与原型Prototype**: JavaScript使用`new`关键字创建对象实例,原型链允许对象间共享属性和方法,`__proto__`或`prototype`属性是理解这一机制的关键。 3. **函数对象Function**: 在JavaScript中,函数...

    面向对象JavaScript开发

    JavaScript,作为一种广泛应用于Web开发的动态脚本语言,最初被设计为简单的客户端脚本语言,但随着技术的发展,它已经发展出了丰富的面向对象编程(OOP)特性。面向对象JavaScript开发是现代Web开发中不可或缺的一...

    JavaScript中prototype的使用

    JavaScript中的`prototype`属性是实现面向对象编程的关键概念之一,尤其在JavaScript中,它用于实现对象的继承。本文将深入探讨`prototype`的含义、作用以及如何使用。 1. **什么是prototype** 在JavaScript中,每...

    JavaScript通过prototype给对象定义属性用法实例

    本文实例讲述了JavaScript通过prototype给对象定义属性的用法。分享给大家供大家参考。具体分析如下: 下面的JS代码定义了movie对象。在使用对象的过程中又通过prototype给对象添加了isComedy属性,调用的时候直接...

    prototype_oop_javascript_ruby_prototype_

    标题 "prototype_oop_javascript_ruby_prototype_" 暗示了我们将探讨的是关于原型(Prototype)面向对象编程(Object-Oriented Programming, OOP)的概念,主要关注JavaScript和Ruby这两种语言之间的相似性和差异性...

Global site tag (gtag.js) - Google Analytics