js prototype 理解
简单理解:prototype对象是实现面向对象的一个重要机制。每个函数也是一个对象,它们对应的类就是
function,每个函数对象都具有一个子对象prototype。Prototype 表示了该函数的原型,
prototype表示了一个类的属性的集合。当通过new来生成一个类的对象时,prototype对象的属
性就会成为实例化对象的属性。 (类似反射出来的一样)
ps.(在JS 里面 全都是对象, 类Function是function的顶级超类,function实例化了叫对象,在function未实例定义的时候,其实这个定义也是属于Function)
<script>/** 关于prototype,理解这个很有必要* 可以在类型上使用proptotype来为类型添加行为。这些行为只能在类型的实例上体现。* JS中允许的类型有Array, Boolean, Date, Enumerator, Error, Function, Number, Object, RegExp, String* 以后这样分,没有实例化的类称为类型,实例化的类称为对象实例简称实例*/Object.prototype.name = "zhangsan";Object.prototype.nihao = function(){alert("i can method name is "+this.name);}var obj = new Object();obj.nihao();alert(obj.name);//在实例上不能使用prototype,否则会发生编译错误obj.prototype.sex = "男";//error,无法给一个实例prototypevar o = {name:"zhangsan"}o.prototype.age = 30;//error,无法给一个实例prototype//可以为类型定义“静态”的属性和方法,直接在类型上调用即可alert(Object.name);Object.nihao();//实例不能调用类型的静态属性或方法,否则发生对象未定义的错误。Object.class = "三年二班";//类静态属性var ob = new Object();alert(ob.class); //error 实例不能调用类型的静态属性和方法//可以在外部使用prototype为自定义的类型添加属性和方法。function Mytest(){this.name = "zhangsan";this.age = 20;}Mytest.prototype.hello = function(){alert(this.name);}var m = new Mytest();m.hello();//在外部不能通过prototype改变自定义类型的属性或方法。//该例子可以看到:调用的属性和方法仍是最初定义的结果。Mytest.prototype.name = "lisi";var mm = new Mytest();alert(mm.name);//可以在对象实例上改变或增加属性。(这个是肯定的)//也可以在对象上改变或增加方法。(和普遍的面向对象的概念不同)mm.name2 = "lisi";mm.hello = function(){alert(this.name2);}//mm.hello();//继承,这个例子说明了一个类型如何从另一个类型继承。function Mytest2(){}Mytest2.prototype = new Mytest;var m2 = new Mytest2();alert(m2.name);//这个例子说明了子类如何重写父类的属性或方法。Mytest2.prototype.name = "wangwu";Mytest2.prototype.hello = function(){alert('i can mytest2 extend Mytest save method hello');}var m3 = new Mytest2();m3.hello();//子类中的name属性值不会被父类覆盖function Mytest3(){this.name = "子类中的name属性值不会被父类覆盖";this.age = 20;}Mytest3.prototype = new Mytest();var m4 = new Mytest3();alert(m4.name);</script>
js prototype 理解的更多相关文章
- js面向对象理解
js面向对象理解 ECMAScript 有两种开发模式:1.函数式(过程化),2.面向对象(OOP).面向对象的语言有一个标志,那就是类的概念,而通过类可以创建任意多个具有相同属性和方法的对象.但是, ...
- JS之理解继承
JS之理解继承:https://segmentfault.com/a/1190000010468293 1.call继承,也叫借用构造函数.伪造对象或是经典继承.call继承回把父类的私有属性和方法继 ...
- vue自定义指令(Directive中的clickoutside.js)的理解
阅读目录 vue自定义指令clickoutside.js的理解 回到顶部 vue自定义指令clickoutside.js的理解 vue自定义指令请看如下博客: vue自定义指令 一般在需要 DOM 操 ...
- 深入理解js——prototype原型
之前(深入理解js--一切皆是对象)中说道,函数也是一种对象.它也是属性的集合,你也可以对函数进行自定义属性.而JavaScript默认的给了函数一个属性--prototype(原型).每个函数都有一 ...
- js的prototype理解
转载:https://www.cnblogs.com/douyage/p/8630529.html 在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实 ...
- 对JS prototype的理解
1.什么是prototype? function F() {} f1 = new F();f2 = new F(); 以上的代码,F()是一个构造函数,f1和f2是由这个构造函数产生的对象. prot ...
- js笔记——理解js中的call及apply
call及apply在js里经常碰得到,但一直感觉很陌生,不能熟练使用.怎样才能熟练应用呢? 为什么存在call和apply? 在javascript OOP中,我们经常会这样定义: function ...
- js prototype
1 原型法设计模式 在.Net中可以使用clone()来实现原型法 原型法的主要思想是,现在有1个类A,我想要创建一个类B,这个类是以A为原型的,并且能进行扩展.我们称B的原型为A. 2 javasc ...
- js深入理解"闭包"
一.变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域. 变量的作用域无非就是两种:全局变量和局部变量. Javascript语言的特殊之处,就在于函数内部可以直接读取全局变量 ...
随机推荐
- SRM 212 Div II Level One: YahtzeeScore
题目来源:http://community.topcoder.com/stat?c=problem_statement&pm=1692&rd=5858 比较简单. 代码如下: #inc ...
- [Todo] C++并发编程学习
就主要看这本书吧: <C++并发编程实战_Cpp_Concurrency_In_Action> /Users/baidu/Documents/Data/Interview/C++ < ...
- WebSocket原理分析
Web应用的通信过程通常是客户端通过浏览器发出一个请求,服务器端接收请求后进行处理并返回结果给客户端,客户端浏览器将信息呈现.这种机制对于信息变化不是特别频繁的应用可以良好支撑,但对于实时要求高.海量 ...
- C#实现两个数据库之间的数据上报
用VS2008实现本地数据库上传数据到远程数据.数据能够是一个表,或一个表的部分数据.或查询数据.或数据编辑后上传. 其他VS版本号.复制当中代码就能够.未使用其他不论什么插件.有具体凝视. 单独页面 ...
- ItermCF的MR并行实现
ItermCF的MR并行实现 @(Hadoop) ItermCF的基本思想 基于物品相似度的协同过滤推荐的思想大致可分为两部分: 1.计算物与物之前的相似度 2.根据用户的行为历史,给出和历史列表中的 ...
- IDEA下clean Maven项目
如何调试出窗口: 点击菜单栏View->Tool Windows->Maven projects ♦如下图,选中之后.点击绿色三角形就可以clean了
- ssh-keygen配置
1) 在本地机器中的~/.ssh/目录下执行下命令, ssh-keygen -t dsa 将生成两个文件,id_dsa和id_dsa.pub. 2) 将id_dsa.pub拷贝到远程机器,并且将id_ ...
- Android常用到的一些事件
1:查看是否有存储卡插入 String status=Environment.getExternalStorageState(); if(status.equals(Enviroment.MEDIA_ ...
- GameCenter 使用指南
原地址:http://www.cocoachina.com/gamedev/misc/2010/1022/2229.html GameCenter 为单机游戏为主的 iPhone 游戏平台引入了社会化 ...
- 算法笔记_036:预排序(Java)
目录 1 问题描述 2 解决方案 2.1 检验数组中元素的唯一性 2.2 模式计算 1 问题描述 在计算机科学中,预排序是一种很古老的思想.实际上,对于排序算法的兴趣很大程度上是因为这样一个事实: ...