关于JavaScript中继承的深入理解
JavaScript中我们可以借助原型实现继承。
例如
function baz(){="";}function foo(){}otype=new baz();var myFoo=new foo();;
这样我们就可以访问到baz里的属性oo啦。在实际使用中这个样不行滴,由于原型的共享特点(数据保存在了堆上),
所有实例都使用一个原型,一但baz的属性有引用类型就悲剧了,一个实例修改了其他实例也都跟着变了wu
自然就有了组合式继承
function baz(){="";}=function(){}function foo(){(this);//第二次调用}otype=new baz();//第一次调用var myFoo=new foo();;;
这样就会有一个问题,代码里也表明出来了,baz会被调用两次,身为处女座的怎么可以允许呢..
插一句,第二种方式就不用出现第一种方式的问题吗?答案是不会的。
原因是属性的查找是先从对象自身开始,没找到才会去原型中去找,call时就把属性给继承了。
再插一句,那这样只使用call继承不就行了吗?如果不使用原型这个是可行的,但是作为处女座怎么能不使用原型呢,
在原型上方法是共享的,这样性能就好了很多呀。
寄生组合式继承
__extends=function (p,c){function ctor(){tructor=c;//赋值构造函数}otype=otype;otype=new ctor();}function baz(){=[1];}=function(){}__extends(baz,foo);function foo(){(this);}var myFoo=new foo();;;
这样不但解决了两次调用的`问题,还解决了对象调用构造函数时调用的是真实的创建对象的函数而不是原型链上其他的构造函数。
代码里有表明。
构造函数是原型对象上的一个属性,是对象的创建者。由于我们的原型属性被从新赋值了所以构造函数时继承来的。
这里要说一下,对象是怎样创建,也就是new都干了些什么。
例如:
var a=new b();
其实是这样的,a={};创建了一个给a,然后(a);call里初始化a,在call之前还有一步,就是a的内部原型对象
设置为b的原型属性指向的原型对象。原型上有构造函数属性,构造函数用来创建对象分配内存控件。
大概就这些...看看时间也不早了,碎吧,保持平和的心态切勿浮躁,努力去改变明天,希望一切都会慢慢变好。
相關文章
-
深入理解Javascript的继承和原型链
在上一篇文章中,介绍了原型的概念,了解到在javascript中构造函数、原型对象、实例三个好基友之间的关系:每一个构造函数都有一个“守护神”——原型对象,原型对象心里面也存着一个构造函数的“位置”,两情相悦,而实例呢却又 -
深入理解Javascript中的this关键字
文章主要介绍了深入理解Javascript中的this关键字,本文讲解了方法调用模式、函数调用模式、构造器调用模式、apply调用模式中this的不同之处,需要的朋友可以参考下,就跟随本站小编一起去了解下吧,想了解更多相关信息请 -
javascript中js闭包的深入理解
闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现。本文是本站小编搜索整理的关于javascript中js闭包的深入理解,给大家做个参考,希望对大家有所帮助!想了解更多相关信息请持续关注我 -
关于深入理解JavaScript中的对象的介绍
JavaScript是一种面向对象编程(OOP)语言。一种编程语言可以被称为面向对象的,它为开发者提供了四种基本功能:封装 - 存储相关的信息,无论是数据或方法,还是对象 聚合 - 存储一个对象到另一个对象的内部 继承 - 类的能力依 -
深入理解javaScript中事件驱动
javascript中的事件驱动是通过 鼠标或热键 的动作引发的 主要事件如下:1、鼠标单击事件 onclick通常用于如下控件:button 按钮对象checkbox 复选框或检查列表 --配合onclick单击事件,通常用于全选效果radio 单选按纽rese -
理解JavaScript中的封装与继承特性
JavaScript中的封装封装简单地说就是让外界只能访问对象的共有变量和函数,隐藏细节和数据。js中有三种方法创建对象,分别为门户大开型、用命名规范区分私有变量、闭包创建真正的私有变量三种。1.门户大开型,是实现对 -
浅谈javascript深入理解js闭包
一、什么是闭包?“官方”的解释是:所谓“闭包”,指的是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。相信很少有人能直接看懂这句话,因为他描述的太学术。我想用 -
深入理解Javascript中自执行匿名函数
格式:(function(){//代码})();解释:这是相当优雅的代码(如果你首次看见可能会一头雾水:)),包围函数(function(){})的第一对括号向脚本返回未命名的`函数,随后一对空括号立即执行返回的未命名函数,括号内为匿名函数的参数。来个 -
关于javascript 原型链维护和继承详解
一.两个原型很多人都知道javascript是原型继承,每个构造函数都有一个prototype成员,通过它就可以把javascript的继承演义的美轮美奂了.其实啊,光靠这一个属性是无法完成javascript的继承.我们在代码中使用的prototype -
有关深入理解JavaScript中的并行处理的介绍
前言为什么说多线程如此重要?这是个值得思考的问题。一直以来,派生线程以一种优雅的方式实现了对同一个进程中任务的划分。操作系统负责分配每个线程的时间片,具有高优先级并且任务繁重的线程将分配到更多的时间片,而低优