私有静态变量

javascript高级程序设计代码

(functions(){

   var name=" ";

   Person = function(value){

            name=value;

            }

  Person.prototype.getName = function () {

             return name;

           }

      Person.prototype.setName = function () {

             name= value;

          }

)();

var person1 = new Person ("xiu");//Person前没有加var变量,定义的是一个全局变量,能够在私有作用域之外被访问到,直观理解就是可以直接创建实例对象

alert (person1.getName()); //xiu

person1.setName("xie");

alert(person1.getName());//xie

 

var persson2 = new Person("baobao");

alert(person2.getName());//baobao

alert(person1.getName());//baobao 

name属性就成了静态私有变量

当我们修改在Person的构造函数里添加var变量的时候,相当于在函数作用域中重新定义了一个新的name属性。

(functions(){

   var name="111";

   Person = function(value){

           var  name=value;

            }

  Person.prototype.getName = function () {

             return name;

           }

      Person.prototype.setName = function (value) {

             name= value;

          }

)();

var person1 = new Person ("xiu");

alert (person1.getName()); //111

person1.setName(“xie”);

alert(person1.getName());//xie

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

块级作用域的问题

(function(){
           var name=10;
           Person=function(){};

           Person.prototype.sayName=function(){

                              alert(name+5);

              };

           var friend = new Person();//创建一个实例对象

           friend.sayName(); //15 搜索到的是原型对象的sayName方法

})();

 

(function( ){...})( );在函数内部的一个作用域内

Person前没有加var变量,定义的是一个全局变量,能够在私有作用域之外被访问到,直观理解就是可以直接创建实例对象

当我创建这个实例对象并调用sayName()方法的时候,首先搜索实例对象中是否有sayName()这个方法,没有再找Person原型对象中是否有这个方法,找到了

然后执行这个方法,里面有个name属性,在没有加this的情况下,首先是找原型对象的sayName()方法里面是否有name这个属性,没有就在这个私有作用域function里面找name属性,一级一级往上找,找到了在私有作用域找到了name属性,这个私有作用域里面的name属性值又可以通过构造函数来改变,所以每次创建一个新实例的时候,name属性值都会改变

在添加this的情况下,首先会找实例对象里是否有name这个属性,没有就在原型对象里面找这个属性

---------------------------------------------------------------------------------------------------------

当去掉函数块级作用域之后

           var name=10;
           var Person=function(){};

           Person.prototype.sayName=function(){

                              alert(name+5);

              };

           var friend = new Person();//创建一个实例对象

           friend.sayName(); //105 为什么是105,我也不知道,测试name变成了string类型的

posted @ 2017-03-06 16:23  我啊我  阅读(1561)  评论(0编辑  收藏  举报