javascript – 使用.call / .apply隐藏类方法

前端之家收集整理的这篇文章主要介绍了javascript – 使用.call / .apply隐藏类方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

有人可以解释一下Single Page Apps in Depth的摘录意味着什么吗?

A common pattern for classes (e.g. objects instantiated from a
prototype) is to simply mark class methods as private by starting them
with a underscore. You can properly hide class methods by using
.call/.apply to set “this”
,but I won’t show it here; it’s a minor
detail.

我认为有一种方法可以实际上使“私有”JavaScript方法实际上无法访问,而不是仅使用下划线标记它们的惯例,但我无法想象实现的样子,以及如何使用它.

最佳答案
var Treasure = function(){  
  function locate(){
    return this.x * this.y + 31337;
  }

  function Treasure(x,y){
    this.x = x;
    this.y = y;
  }

  Treasure.prototype.find = function find(){
    return locate.call(this);
  };

  return Treasure;
}();

locate是构造函数和原型方法的共享私有函数.使用调用它可以像一个方法,并利用它.

这个概念的更完整的实现是接口对象和实现对象.您实际上创建了一个私有的整个类,而不是使用一些随机函数作为方法(类似于上面的定位).接口的每个外部创建都会导致两个对象:公共shell接口和私有实现对象.这允许您公开一个提供不同的,可能更容易使用的API的接口.或者可以允许您为整个接口对象组重用单个私有实现对象.

这实际上是指定DOM的工作方式(通常不会在js中实现).特别需要接口对象(例如元素和节点对象)来包装实际执行该单词的底层实现.暴露的对象只是转发属性访问和方法调用的shell.

Dom.js是用js制作的完整的DOM实现.我在使用它时熟悉的一个有趣的技术是完全自动生成公共接口.这是IDL的目的:公共API实际上是自动生成的,只留下实际创建的私有实现.这真的意味着可以在不咨询人类的情况下创造这样的事情:https://github.com/Benvie/svgstuff/blob/master/lib/defs.js

猜你在找的JavaScript相关文章