javascript的私有变量和全局变量
要写一个jquery插件,可以实例化插件并传递不同的参数给不同的div。实例化时碰到问题。
首先讲下函数中变量的私有性。
function initMp3(options){
var isPlaying = false;
var audioImg;
var audio;
……
}
任何在函数中定义的变量和函数都可以认为是私有变量。即使var entity = new initMp3(),也是无法访问到entity.isPlaying;
但是若在函数内定义this.isplaying,则可以在实例中访问到。因为this.isplaying是公有的。
访问这些私有变量的方式可以通过在函数中定义一个this.isplaying的闭包,并在闭包内访问私有变量。
this.isplaying = function(){return audioImg};
可以通过这种方式隐藏不应该被直接修改的数据。
下面给个闭包中的变量定义的私有和全局范围的例子
(function(){
//私有属性 不能实例化
function testFunc(obj){
var a = obj.a;//私有属性。不能通过实例访问
var b = obj.b;
console.log(a + "," + b);
this.options = {//成员属性可以通过实例访问
"a": a,
"b": b
}
};
this.outerFunc = testFunc;//成员属性 可以实例化
Gloable = "abc";//全局对象
})();
var test = new outerFunc({
"a": 13,
"b": 144
});
var test2 = new outerFunc({
"a": 00,
"b": 10
});
console.log(test.options);//13 144
console.log(test2.options);//00 10
console.log(Gloable);//abc
//引用类型 和值类型传递
var isDo = {isdo:true};
var obj = {isDo2:isDo};
obj.isDo2.isdo = true;
console.log(obj.isDo2);//false 输出最后的值
console.log(isDo);//false
isDo.isdo = false;
console.log(obj.isDo2);//false
console.log(isDo);//false
参考《javascript 高级程序设计第二版》第七章