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