javascript私有变量的警告
Javascript从未阻止我们将一个对象中创建的属性复制给另一个对象。观察如下代码:
console.log("------------通过函数访问私有变量,而不是通过对象访问-------------");
function NinjaTest() {
var feints = 0;
this.getFeints = function () {
return feints;
}
this.feint = function () {
feints++;
}
}
var ninjaTest1 = new NinjaTest();
ninjaTest1.feint();
var imposter = {};
//将'ninjaTest1'的对象方法'getFeints'赋值给对象'imposter'
imposter.getFeints = ninjaTest1.getFeints;
//验证我们访问‘ninjaTest1’对象的私有变量
if (imposter.getFeints() === 1) {
console.log("The imposter has access to the feints varibale!");
}
将ninjaTest1的对象方法getFeints赋值给一个新的imposter对象。然后,我们通过对象impostor的getFeints方法,可以测试是否可以访问ninjaTest1对象的私有变量,这样,验证了我们是在假装这些是“私有”变量。
上述代码表明在JavaScript中没有真正的私有对象属性,但是可以通过闭包实现一种可接受的“私有”变量的方案。尽管如此,虽然不是真正的私有变量,但是许多开发者发现这是一种因此信息的有用方式。
管该函数是对象的方法,但是我们仍然可以通过该函数访问“私有”变量。
参考《JavaScript忍者秘籍》