JavaScript小进阶12--闭包助力OOP之模拟私有成员属性

思维引导:(和java对比)

       由于函数体内声明的局部变量我们是无法访问的,这个特征类似java中的private 成员属性,所以我们可以将这些声明的局部变量看作private成员属性。Js中闭包的特性,让我们可以将function中的局部变量在函数体执行完毕后保留下来(即不让回收),如此一来就提供了思路给我们来模拟java的private成员。

       代码设计如下:

       function Person(){

         var name ;

         var age;

         this.setName = function(p_name){ name = p_name ; };

         this.getName = function(){ return age; };

         this.setAge = function(p_age){ age = p_age; };

         this.getAge = function(){ return age; };

       }

       成员属性可见性的模拟:js中没有static ,private,public属性的概念,仅仅是模拟!!

       模拟公有成员属性:java中的成员变量我们可以直接这样访问:对象名.属性名,类似的,js对象中,语法上也是同样的属性访问方式,因此我们可以将js对象中的属性都看作是public成员。如:

       var man = {name : “luozhixiao”};

       console.log( man.name );

       模拟静态属性:java中,static属性/函数是属于类的,调用方法是:类名.属性名  /  类名.方法名()

       注意:js中无法模拟protected 成员属性。

tips:

          事到如今,js可以模拟java的OOP的大部分精髓。。。。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。