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!");
}

 javascript私有变量的警告

将ninjaTest1的对象方法getFeints赋值给一个新的imposter对象。然后,我们通过对象impostor的getFeints方法,可以测试是否可以访问ninjaTest1对象的私有变量,这样,验证了我们是在假装这些是“私有”变量。

 

上述代码表明在JavaScript中没有真正的私有对象属性,但是可以通过闭包实现一种可接受的“私有”变量的方案。尽管如此,虽然不是真正的私有变量,但是许多开发者发现这是一种因此信息的有用方式。

 

 javascript私有变量的警告

 

管该函数是对象的方法,但是我们仍然可以通过该函数访问“私有”变量。

 

参考《JavaScript忍者秘籍》