欢迎来到天天文库
浏览记录
ID:56007720
大小:47.00 KB
页数:16页
时间:2020-03-15
《浅谈javascript面向对象编程.doc》由会员上传分享,免费在线阅读,更多相关内容在学术论文-天天文库。
1、浅谈javascript面向对象编程默认分类2009-07-1920:23阅读81评论1字号:大大中中小小这周心血来潮,翻看了现在比较流行的几个JS脚本框架的底层代码,虽然是走马观花,但也受益良多,感叹先人们的伟大……感叹是为了缓解严肃的气氛并引出今天要讲的话题,”javascript面向对象编程”,接下来,我们围绕面向对象的几大关键字:封装,继承,多态,展开。封装:javascript中创建对象的模式中,个人认为通过闭包才算的上是真正意义上的封装,所以首先我们先来简单介绍一下闭包,看下面这个例
2、子:functionmyInfo(){varname="老鱼",age=27;varmyInfo="mynameis"+name+"iam"+age+"yearsold";functionshowInfo(){alert(myInfo);}returnshowInfo;}varoldFish=myInfo();oldFish();是不是很眼熟呢?没错了,这其实就是一个简单的闭包应用了。简单解释一下:上面的函数myInf
3、o中定义的变量,在它的内嵌函数showInfo中是可访问的(这个很好理解),但是当我们把这个内嵌函数的返回引用赋值给一个变量oldFish,这个时候函数showInfo是在myInfo函数体外被调用,但是同样可以访问到定义在函数体内的变量。ohyeah!总结一下闭包的原理吧:函数是运行在定义他们的作用域中而不是调用他们的作用域中。其实返回一个内嵌函数也是创建闭包最常用的一种方法!如果觉得上面的解释太抽象的话,那么我们一起重塑上面的函数,看看这样是否层次鲜明一些:4、/javascript">varioldFish=function(name,age){varname=name,age=age;varmyInfo="mynameis"+name+"iam"+age+"yearsold";return{showInfo:function(){alert(myInfo);}}}ioldFish("老鱼",27).showInfo();上例中的编码风格是extyui中比较常见的,公私分明,一目了然。通过闭包,我们可以很方便的把一些不希望被外部直接5、访问到的东西隐藏起来,你要访问函数内定义的变量,只能通过特定的方法才可以访问的到,直接从外部访问是访问不到的,写的挺累,饶了一圈终于转回来了,封装嘛,不就是把不希望被别人看到的东西隐藏起来嘛!哈哈……上例如果转换成JQ的风格的话,应该如下例所写,这样的封装模式属于门户大开型模式,里面定义的变量是可以被外部访问到的(下面的例子如果你先实例化一个对象,然后在函数外部访问对象的name或者age属性都是可以读取到的)当然这种模式下我们可以设置一些”潜规则”,让团队开发成员明白哪些变量是私用的,通常我们6、人为的在私有变量和方法前加下划线”_”,标识警戒讯号!从而实现”封装”!varioldFish=function(name,age){returnioldFish.func.init(name,age);};ioldFish.func=ioldFish.prototype={init:function(name,age){this.name=name;this.age=age;returnthis;},showInfo:function7、(){varinfo="mynameis"+this.name+"iam"+this.age+"yearsold";alert(info);}};ioldFish.func.init.prototype=ioldFish.func;ioldFish("老鱼",27).showInfo();//varoldFish=newioldFish("老鱼",27);//alert(oldFish.name);可能有人会问,哪种模式好呢?这个怎么说呢?两种方式都有优缺点,结合着用呗!总之一8、个原则,一定一定不能直接被外部对象访问的东西,就用闭包封装吧。”一定一定”四个字很深奥,不断实践中才能体会真谛!继承:提到这个的时候,要顺便再补充一句:闭包封装中的一个缺点,不利于子类的派生,所以闭包有风险,封装需谨慎!直观起见,下面例子中创建对象的方式,采用”门户大开型”模式。在javascript中继承一般分为三种方式:”类式继承”,”原型继承”,”掺元类”。下面简单的介绍一下三类继承方式的原理。A.类式继承:这个是现在主流框架中常用的继承方式,看下例:
4、/javascript">varioldFish=function(name,age){varname=name,age=age;varmyInfo="mynameis"+name+"iam"+age+"yearsold";return{showInfo:function(){alert(myInfo);}}}ioldFish("老鱼",27).showInfo();上例中的编码风格是extyui中比较常见的,公私分明,一目了然。通过闭包,我们可以很方便的把一些不希望被外部直接
5、访问到的东西隐藏起来,你要访问函数内定义的变量,只能通过特定的方法才可以访问的到,直接从外部访问是访问不到的,写的挺累,饶了一圈终于转回来了,封装嘛,不就是把不希望被别人看到的东西隐藏起来嘛!哈哈……上例如果转换成JQ的风格的话,应该如下例所写,这样的封装模式属于门户大开型模式,里面定义的变量是可以被外部访问到的(下面的例子如果你先实例化一个对象,然后在函数外部访问对象的name或者age属性都是可以读取到的)当然这种模式下我们可以设置一些”潜规则”,让团队开发成员明白哪些变量是私用的,通常我们
6、人为的在私有变量和方法前加下划线”_”,标识警戒讯号!从而实现”封装”!varioldFish=function(name,age){returnioldFish.func.init(name,age);};ioldFish.func=ioldFish.prototype={init:function(name,age){this.name=name;this.age=age;returnthis;},showInfo:function
7、(){varinfo="mynameis"+this.name+"iam"+this.age+"yearsold";alert(info);}};ioldFish.func.init.prototype=ioldFish.func;ioldFish("老鱼",27).showInfo();//varoldFish=newioldFish("老鱼",27);//alert(oldFish.name);可能有人会问,哪种模式好呢?这个怎么说呢?两种方式都有优缺点,结合着用呗!总之一
8、个原则,一定一定不能直接被外部对象访问的东西,就用闭包封装吧。”一定一定”四个字很深奥,不断实践中才能体会真谛!继承:提到这个的时候,要顺便再补充一句:闭包封装中的一个缺点,不利于子类的派生,所以闭包有风险,封装需谨慎!直观起见,下面例子中创建对象的方式,采用”门户大开型”模式。在javascript中继承一般分为三种方式:”类式继承”,”原型继承”,”掺元类”。下面简单的介绍一下三类继承方式的原理。A.类式继承:这个是现在主流框架中常用的继承方式,看下例:
此文档下载收益归作者所有