草庐IT

Java——this关键字

全部标签

javascript - 如何重新实现 'var that = this' 以使用 Object.prototype.bind() 保存范围引用?

在SecretsofJavascriptClosures,StuartLangridge提供了一段代码来演示闭包在.onclick回调中的常见用法,并解释如下:link.onclick=function(e){varnewa=document.createElement("a");varthat=this;document.body.appendChild(newa);newa.onclick=function(e){that.firstChild.nodeValue="reset";this.parentNode.removeChild(this);}}我最近偶然发现了KyleSim

javascript - 调用通过构造函数传入的函数时,我可以避免在 Typescript 中使用单词 "this"吗?

我有:classAdminHomeController{privateconfig1;//Itrieddifferentvariationsherebutnoneworkedpublicconfig2;//constructor(private$scope:IAdminHomeControllerScope){this.config=$scope.config;//{this.config.clear();};}此代码有效,this.config具有我需要的所有方法。但是有没有办法我可以删除对this的需要吗?我希望能够编写以下代码:configChanged=(clear)=>{co

javascript - bind(this) 不适用于 ajax 成功函数

我使用React和jQuery。这是我的代码的一部分。在挂载React组件之前,我执行ajax请求以了解用户是否已登录。应该在响应返回状态码200时设置状态。我是否错误地使用了bind(this)?componentWillMount:function(){$.ajax({url:"/is_signed_in",method:"GET",dataType:"json"}).success(function(response){this.setState({signedIn:response.signed_in,currentUser:$.parseJSON(response.curre

javascript - 我如何像 Java 包一样组织我的 Angular 应用程序文件夹?

如何像Java包一样组织Angular2应用文件夹结构?考虑以下项目布局:app|_model|_component|_service我想将foo.service.ts从service导入到component中的bar.component.ts>。但据我所知,Angular2导入仅支持相对路径,如/../service/,这似乎是非常笨拙的解决方案。有没有一种方法可以从根文件夹引用带有绝对路径的文件夹,就像Java包一样? 最佳答案 更新2016-06-01使用npminstalltypescript@next你已经可以使用这个函数

javascript - this 在箭头函数中未定义

我试图在我的箭头函数中访问它:importmyObjectfrom'../myObjectPath';exportconstmyClass=Fluxxor.createStore({initialize(){this.list=[];this.id=null;},myOutsideFunction(variable1){//herethisinNOTundefinedmyObject.getMyList(this.id,(myList)=>{//herethisinundefinedthis.list=myList;}});)};但是在回调函数中的箭头函数中,this是未定义的!!我正

javascript - for.in 的迭代顺序——不是通过插入(还有吗?)

根据我的研究,for..in循环中键的顺序应该是不确定的/不可靠的——但是,如果不受干扰,应该是插入顺序——但它不是:我从数据库中获取这个数据对象,按名称排序:vartravel={'2':{name:'bus',price:10},'3':{name:'foot',price:0},'1':{name:'taxi',price:100}}for(wayintravel)console.log(travel[way].name)//=>taxi,bus,foot按键按数字排序(在所有Chrome、Firefox和Edge中)。为什么?而且(因为我错了)我如何遍历按.name排序的它们?

javascript - 在 CouchDB 中, 'this' 指的是什么?

我正在尝试了解CouchDB和couchapp,并且随着我的理解,我发现在任何给定的上下文中都很少使用“this”。我知道show对象获取文档和请求,并允许使用列表和View对它们进行操作。这些操作都是Javascript对象。但CouchApp似乎也以字符串形式存储各种东西:README文件、Mustache模板等。它必须以某种方式访问​​它们。show上下文中的this运算符是否以某种方式提供对设计文档根目录的访问,从而通过require以外的其他方式提供对对象的访问语法?在Javascript中,this必须在每个上下文中以某种方式定义,特别是“有一个this值与每个事件执行上下

javascript - 使用 "in"关键字迭代 Javascript 数组

看来我不明白JavaScript中in关键字的含义。看看这个代码片段(http://jsfiddle.net/3LPZq/):varx=[1,2]for(iinx){document.write(x[i]);}在jsfiddle中运行时,它不仅会打印数组中包含的值,还会打印数组对象的所有属性和方法。当我这样更改它时(http://jsfiddle.net/4abmt/):$(document).ready(function(){varx=[1,2]for(iinx){document.write(x[i]);}});它只打印值1和2。为什么会这样?这是由jQuery引起的还是in关键字

javascript - 'var' 声明的变量和 'this' 在 Javascript 中创建的属性有什么区别?

首先使用varfunctiontestCode(some){varsomething=some;}第二次使用这个functiontestCode2(some){this.something=some;} 最佳答案 在第一个函数中,something是一个private(局部)变量,这意味着它在函数外是完全不可访问的;而在第二个中,它是一个public实例变量。设置变量的上下文将取决于您调用函数的方式:>testCode2("foo");//thiswillrefertodocument.window>something"foo">>

javascript - 输入类型="submit",onclick处理程序调用this.form.submit(),并且不返回任何值

编辑:在考虑回答问题之前,请仔细阅读问题的所有内容。我既不是在生产代码中使用内联事件处理程序的可取性,也不是在实现我所引用的文章所promise的结果的最佳方法。这是关于Javascript语义和浏览器实现细节的问题,而不是关于最佳编码实践的问题。听起来像一场噩梦,对吗?但是我发现一些onlineadvice提倡这样做,以防止再次提交表单:撇开对内联事件处理程序的弊端的任何讨论,我在这里看到的问题是:标签的类型是"submit",因此提交其包含形式是其默认行为;onclick处理程序显式提交包含表单;onclick处理程序不返回false以防止默认行为(请参见1)。凭直觉,我认为单击此