草庐IT

private-class

全部标签

javascript - 定义 `that = this` 将如何帮助我创建私有(private)变量/成员?

我正在阅读DouglasCrawford'spiece关于在javascript类中创建私有(private)变量。他在其中说您必须声明that=this以“使对象可用于私有(private)方法”。但是,我能够构建一个具有私有(private)成员、私有(private)方法和公共(public)方法的示例,而无需定义that=this:functionForm(id_code){//privatevariablevarid_code=id_code;varcolor='#ccc';//privatemethodfunctionbuild_style_attribute(){retu

javascript - 使用javascript向第一个 child 添加类(class)

这个链条不工作有什么原因吗?它不添加类:document.getElementsByTagName('nav')[0].firstChild.className="current"它应该返回nav元素的第一个子元素,它是一个。这不会发生。感谢您的帮助! 最佳答案 那是因为你有textnodes在nav之间和a.您可以通过nodeType过滤它们:varchildNodes=document.getElementsByTagName('nav')[0].childNodes;for(vari=0;ibreak;}}这可能看起来很奇怪,

javascript - 在 JavaScript 中 : Syntax difference between function & method definition within a class

Object类同时具有方法和函数,这意味着它们都可以通过Object.nameOfMethodOrFunction()访问。下面的问题Whatisthedifferencebetweenamethodandafunction解释了方法和函数之间的区别,但没有解释如何在对象中创建它们。例如,下面的代码定义了方法sayHi。但是如何在同一个对象中定义一个函数呢?varjohnDoe={fName:'John',lName:'Doe',sayHi:function(){return'HiThere';}}; 最佳答案 下面定义了两个类,C

javascript - 揭示原型(prototype)模式私有(private)变量

我在JavaScript的揭示原型(prototype)模式中遇到私有(private)变量问题。我无法弄清楚如何在共享(单例)原型(prototype)内的几个不同函数中使用私有(private)变量,而不公开它们。这是我在JSFiddle中的意思的例子.问题在于使用varv与this.v。第一个会扰乱所有实例的状态,但第二个是公开可见的。有没有办法让v私有(private),并为每个单独的实例保留其状态? 最佳答案 没有办法用揭示原型(prototype)模式来做到这一点。你只能用这样的东西来做到这一点:functionMyCl

javascript - AngularJS 指令中的单元测试私有(private)函数

如何对在指令内定义的函数进行单元测试,如下面的myFunc?angular.module('myApp').directive('myDir',[function(){varmyFunc=function(arg){//codeinhere.};return{restrict:'A',scope:{},link:function(scope,element){}};}]);或者您如何定义我不想在指令之外公开的可测试指令特定函数? 最佳答案 最常见的方法是不测试私有(private)方法,而是测试公开其行为的公共(public)接口(

javascript - 重访 Python 私有(private)实例数据

我读过各种“Python实例中没有真正私有(private)数据”的帖子,但我们都知道在Perl和JavaScript中使用闭包来有效实现私有(private)数据。那么为什么不用Python呢?例如:importcodecsclassSecret:def__private():secret_data=Nonedef__init__(self,string):nonlocalsecret_dataifsecret_dataisNone:secret_data=stringdefgetSecret(self):returncodecs.encode(secret_data,'rot_13

JavaScript ES6 : Grouping methods in es6 classes?

我们中的一些人正在尝试创建一个JavaScript库以在RESTfulAPI上快速运行JSON查询。我想做的是根据它们的目的对一组方法进行分组。例如;通过API,我能够获取用户属性。我不想将所有这些方法都放在主对象下,而是将它们分组在API类对象中。即转换这个:myAPI.getUserById()为此:myAPI.User.getByID()myAPI.User.getByName()我们将使用下面的代码作为一个简单示例。我如何将我的用户方法嵌套在myAPI类的用户对象中??classmyAPI{constructor(url){this.url=url;//Codetoconnec

javascript - 从 Angular 5 组件访问父类(super class)字段

我有一个包含组件通用功能的父类(superclass)。exportclassAbstractComponentimplementsOnInit{publicuser:User;constructor(publichttp:HttpClient){}ngOnInit():void{this.http.get('url').subscribe(user=>{this.user=user;});}}我有一个实现这个父类(superclass)的子类。@Component({selector:'app-header',templateUrl:'./header.component.html'

javascript - angular ng-class对点击没有反应

我正在尝试使用ng-class并将一个类绑定(bind)到一个表达式,这样我就可以对表达式绑定(bind)进行单元测试。但是,我似乎遗漏了什么。按钮:addinterface应该折叠和展开的面板:被触发的函数$scope.onAddInterface=function(){$scope.showCreateNewInterfacePanel=true;}无论如何点击链接没有任何反应。我错过了什么吗? 最佳答案 我不确定这是否是您真正定义$scope.onAddInterface函数的方式,或者它是否只是一个示例...不过您应该这样做

javascript - 捆绑 JavaScript 类(class) Uncaught SyntaxError : Unexpected token <

使用mvc4类(class)的bundle特性UncaughtSyntaxError:Unexpectedtoken正在加载。使用debug="true"一切正常。我该如何解决这个错误,或者我是否可以只为脚本禁用捆绑功能?已解决重命名包名称以与任何目录不匹配 最佳答案 在回答导致此错误的原因之前,您必须先找出错误发生的位置。捆绑时代码语法的唯一区别是它被缩小了。一个非常简单的方法是使用Bundle而不是ScriptBundle:varthirdParty=newBundle("~/bundles/thirdParty").Inclu