日期:2014-05-16  浏览次数:20397 次

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 高级程序设计第二版》第七章