• 私有静态变量


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

  • 相关阅读:
    confluence的安装、破解和汉化
    Linux学习经验集锦
    MFS 分布式文件系统
    MFS
    Docker 搭建 WordPress
    ansible入门
    docker搭建pxc集群与haproxy负载均衡
    mysql-proxy 实现读写分离
    Linux内核学习总结
    lab8:理解进程调度时机跟踪分析进程调度与进程切换的过程
  • 原文地址:https://www.cnblogs.com/aixiuxiu/p/6510517.html
Copyright © 2020-2023  润新知