zoukankan      html  css  js  c++  java
  • 私有静态变量

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

  • 相关阅读:
    3.消息队列和事件循环
    2.V8工作原理
    1.浏览器中的Javascript执行机制
    入前端之门半年的感想
    前端面试相关知识点整理记录
    Nginx报错——upstream timed out 10060
    浅谈偏向锁、轻量级锁、重量级锁
    Debug 的一点思路
    Shiro 之 HashedCredentialsMatcher 认证匹配
    计算机网络基础 之六:应用层
  • 原文地址:https://www.cnblogs.com/aixiuxiu/p/6510517.html
Copyright © 2011-2022 走看看