私有静态变量

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类型的

转载于:https://www.cnblogs.com/aixiuxiu/p/6510517.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值