鉴于自己在JavaScript这方面比较薄弱,所以就找了一本书恶补了一下(被称为犀利书的JavaScript权威指南)。书的内容虽然多了点,但这也充分说明了js中的东西还是挺多的。虽然我们的定位不是前端,但最好还是了解一下js这个发展了将近20年但依然很火的技术。
两年前,写过一篇关于JavaScript闭包的博客,所以对闭包这个词印象很深,在看这书的时候,又看到了闭包,那么这次再看闭包,会有什么不同的理解呢?
大家都知道,在JavaScript中是没有类的概念的,更没有私有、公有的成员变量这样的概念。但是它又是确确实实存在着这些东西。
看下面例子:
function MyClass(){ this.name='李四'; var age=2; } var test=new MyClass(); alert(test.name); //李四 alert(test.age) //undefined test.name='张三';
那么对于private的变量应该怎样访问呢?
在Java中对于private的变量,我们要访问它,是为其提供了get、set方法对其进行操作,在这里也一样。看下面代码:
function MyClass(){ this.name='李四'; var age=2; this.getAge=function(){ alert(age); } this.setAge=function(value){ if(value>0 && value < 150) age=value; } } var test=new MyClass(); test.getAge() //2 test.setAge(11); test.getAge(); //11
对于私有属性操作的方式,在JavaScript中有一个特有的称呼:闭包。
通过Java类的声明来理解JavaScript,突然发现曾经认为难以理解的闭包,变得不太理解为什么定义这样一个概念。
虽然目前为止还没有生成javascript属性的get、set方法,但ext已经提供了这样的工具方法来使javascript对象的属性直接具有get、set方法。
在以往的javascript使用过程中,我们更多的是采用面向过程方式,这也就暴露了我们对于js代码的复用程度很低。js的面向对象,势在必行。
JavaScript中面向对象那点事,布布扣,bubuko.com
原文:http://blog.csdn.net/jianxin1009/article/details/35568169