JS中的prototype

2011-06-03 14:40 by 轩脉刃, 17040 阅读, 16 评论, 收藏, 编辑

JS中的phototype是JS中比较难理解的一个部分

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

1 原型法设计模式

在.Net中可以使用clone()来实现原型法

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

2 javascript的方法可以分为三类:

a 类方法

b 对象方法

c 原型方法

例子:

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

//测试

var p1=new People("Windking");

p1.Introduce();

People.Run();

p1.IntroduceChinese();

3 obj1.func.call(obj)方法

意思是将obj看成obj1,调用func方法

好了,下面一个一个问题解决:

prototype是什么含义?

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

A.prototype = new B();

理解prototype不应把它和继承混淆。A的prototype为B的一个实例,可以理解A将B中的方法和属性全部克隆了一遍。A能使用B的方法和属性。这里强调的是克隆而不是继承。可以出现这种情况:A的prototype是B的实例,同时B的prototype也是A的实例。

先看一个实验的例子:

function baseClass()
{

this.showMsg =function()
{
    alert("baseClass::showMsg");  
}

}

function extendClass()
{

}

extendClass.prototype =new baseClass();

var instance =new extendClass();

instance.showMsg(); // 显示baseClass::showMsg

我们首先定义了baseClass类,然后我们要定义extentClass,但是我们打算以baseClass的一个实例为原型,来克隆的extendClass也同时包含showMsg这个对象方法。

extendClass.prototype = new baseClass()就可以阅读为:extendClass是以baseClass的一个实例为原型克隆创建的。

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

下面是扩展实验2:

function baseClass()
{
this.showMsg =function()
   {
       alert("baseClass::showMsg");  
   }
}

function extendClass()
{
this.showMsg =function ()
   {
       alert("extendClass::showMsg");
   }
}

extendClass.prototype =new baseClass();
var instance =new extendClass();

instance.showMsg();//显示extendClass::showMsg

实验证明:函数运行时会先去本体的函数中去找,如果找到则运行,找不到则去prototype中寻找函数。或者可以理解为prototype不会克隆同名函数。

那么又会有一个新的问题:

如果我想使用extendClass的一个实例instance调用baseClass的对象方法showMsg怎么办?

答案是可以使用call:

extendClass.prototype =new baseClass();
var instance =new extendClass();

var baseinstance =new baseClass();
baseinstance.showMsg.call(instance);//显示baseClass::showMsg

这里的baseinstance.showMsg.call(instance);阅读为“将instance当做baseinstance来调用,调用它的对象方法showMsg”

好了,这里可能有人会问,为什么不用baseClass.showMsg.call(instance);

这就是对象方法和类方法的区别,我们想调用的是baseClass的对象方法

最后,下面这个代码如果理解清晰,那么这篇文章说的就已经理解了:

<script type="text/javascript">

function baseClass()
{
this.showMsg =function()
   {
       alert("baseClass::showMsg");  
   }

this.baseShowMsg =function()
   {
       alert("baseClass::baseShowMsg");
   }
}
baseClass.showMsg =function()
{
   alert("baseClass::showMsg static");
}

function extendClass()
{
this.showMsg =function ()
   {
       alert("extendClass::showMsg");
   }
}
extendClass.showMsg =function()
{
   alert("extendClass::showMsg static")
}

extendClass.prototype =new baseClass();
var instance =new extendClass();

instance.showMsg(); //显示extendClass::showMsg
instance.baseShowMsg(); //显示baseClass::baseShowMsg
instance.showMsg(); //显示extendClass::showMsg

baseClass.showMsg.call(instance);//显示baseClass::showMsg static

var baseinstance =new baseClass();
baseinstance.showMsg.call(instance);//显示baseClass::showMsg

</script>

作者:轩脉刃(yjf512)
出处:(http://www.cnblogs.com/yjf512/)
版权声明:本文的版权归作者与博客园共有。欢迎转载阅读,转载时须注明本文的详细链接。

转载于:https://blog.51cto.com/elick/1219836

JS中的prototype相关推荐

  1. JS中的prototype、__proto__与constructor

    作为一名前端工程师,必须搞懂JS中的prototype.__proto__与constructor属性,相信很多初学者对这些属性存在许多困惑,容易把它们混淆,本文旨在帮助大家理清它们之间的关系并彻底搞 ...

  2. js中的prototype的理解

    2019独角兽企业重金招聘Python工程师标准>>> JS中的prototype是JS中比较难理解的一个部分 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原 ...

  3. JS中的prototype、__proto__与constructor(图解)

    作为一名前端工程师,必须搞懂JS中的prototype.__proto__与constructor属性,相信很多初学者对这些属性存在许多困惑,容易把它们混淆,本文旨在帮助大家理清它们之间的关系并彻底搞 ...

  4. JS中对于prototype的理解

    JS中的prototype是JS中比较难理解的一个部分 本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个 ...

  5. 帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)

    帮你彻底搞懂JS中的prototype.__proto__与constructor(图解) 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文 ...

  6. 这一篇彻底搞懂JS中的prototype、__proto__与constructor真的很好

    文章目录 1. 前言 2. _ _ proto _ _ 属性 3. prototype属性 4. constructor属性 5. 总结 提示:不要排斥,静下心来,认真读完,你就搞懂了!(可以先看一下 ...

  7. (转)帮你彻底搞懂JS中的prototype、__proto__与constructor(图解)

    文章目录 1. 前言 2. _ _ proto _ _ 属性 3. prototype属性 4. constructor属性 5. 总结 提示:不要排斥,静下心来,认真读完,你就搞懂了!(可以先看一下 ...

  8. 关于JS中的prototype介绍

    转自:微点阅读  https://www.weidianyuedu.com JS中的phototype是JS中比较难理解的一个部分 本文基于下面几个知识点: 1 原型法设计模式 在.Net中可以使用c ...

  9. JS中的prototype、__proto__与constructor,原型和原型链

    理解原型的几个关键点: 1.所有的引用类型(数组.函数.对象)可以自由扩展属性(除null以外); 2.所有的引用类型(对象)都有一个'_ _ proto_ _'属性(也叫隐式原型,它是一个普通的对象 ...

最新文章

  1. 存储方式与介质对性能的影响
  2. 如何做研究与写论文?周志华大佬教您方法论!
  3. Python3--批量爬取数据之调用百度api进行翻译
  4. idea maven 创建webapp项目没有src目录
  5. mysql映射文件_Mybatis SQL映射文件
  6. 风控分析秘籍R-I-S-K
  7. Mac OSX 下如何显示隐藏文件
  8. php 脚本调试,PHP 调试脚本
  9. 文件扫描生成PDF文件或图片,扫描效果碾压WPS及全能扫描王
  10. 在Virtualbox虚拟机中安装MSDOS(简易教程)
  11. windows删除文件夹时提示:你需要权限来执行此操作
  12. XCOM串口调试软件的安装与使用(附串口及驱动资源包)
  13. PC端实现微信支付功能(Vue2.0)
  14. linux大于3T硬盘多个分区,Ubuntu挂载3T硬盘或大于2T磁盘的方法
  15. Fiddler抓包1-查看get与post请求
  16. MATLAB程序:IEEE802.16d路径损耗模型
  17. 使用Navicat复制MySQL数据库
  18. 解决PotPlayer播放视频没有声音
  19. smtp java 抓包_[Wireshark]_003_电子邮件抓包分析
  20. Sentinel 流控(限流)

热门文章

  1. Blazor将.NET带回到浏览器
  2. Android实现仿QQ登录界面背景动画效果
  3. sass @function,@for,@mixin 的应用
  4. Facebook暂停中国工具类应用广告
  5. HDU 1285--确定比赛名次【拓扑排序 amp;amp; 邻接表实现】
  6. CentOS上编译安装Nginx
  7. ShaderLab Syntax 基本语法
  8. 忘记Windows 7 登录密码,3分钟我来搞定
  9. 构建你的第一个Vue.js组件
  10. 自定义present和dismiss的转场动画