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 高级程序设计第二版》第七章
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值