草庐IT

ref_this

全部标签

javascript - 'this' 绑定(bind)到订阅函数而不是 Angular2 中的外部组件范围

我在Angular2中的一个组件中遇到问题,因为“this”在我的一个组件中绑定(bind)到错误的上下文。我有其他组件没有发生此问题,但我看不出有什么区别。这是我的代码:组件:import{Component,Input}from'@angular/core';import{FilesService}from"./services/files.service";@Component({selector:'my-app',moduleId:module.id,templateUrl:'/app/views/app.html'})exportclassAppComponent{openF

javascript - 使用 Redux、React 和 react-router-dom 4.x 时从动态组件获取 ref

我有以下类(class)classMatchBoxextendsReact.Component{constructor(props){super(props);this.countdownHandler=null;this.showBlocker=true;this.start=this.start.bind(this);}start(){...}render(){...return(...);}};functionmapStateToProps(state){...}functionmatchDispatchToProps(dispatch){...}exportdefaultwit

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 - 为什么 'this' 的值从文档到窗口变化

在下面的代码中我无法理解为什么this的值更改为window来自document在函数中handler当我从document调用它时语境。$(document).ready(function(){varhandler=function(){console.log(this);//this=window}console.log(this);//this=documenthandler();})根据我的理解this的值(value)由其执行上下文确定。现在当我document.ready函数this指向document这是预期的,但是当我从该上下文调用方法时,为什么我的上下文更改为wind

javascript - `this._super(controller,model)` 在 Ember 路由器中意味着什么?

我在EmberJS代码和讨论{未提供引用}中看到以下内容:代码路由.jssetupController:function(controller,model){this._super(controller,model);//Morecode},问题这里对this._super(controller,model);的调用是做什么的?什么时候需要使用这种类型的调用?只是想在这里学习,因为我的Nose因Ember学习曲线而流血。 最佳答案 正如@RyanHirsch所说,this._super调用该方法的父实现。在setupControll

javascript - `this` 在全局上下文和内部函数中

根据thisexplanationinMDN:在全局上下文中,this指的是全局对象在函数上下文中,如果函数被直接调用,它又引用了全局对象然而,以下内容:varglobalThis=this;functiona(){console.log(typeofthis);console.log(typeofglobalThis);console.log('isthistheglobalobject?'+(globalThis===this));}a();...放在文件foo.js中产生:$nodejsfoo.jsobjectobjectisthistheglobalobject?false

javascript - Ember "this"在组件中未定义

我正在尝试制作一个进度条,它会随着更多挑战的完成而更新。但是,组件无法访问该属性,因为它是未定义的。我已经注入(inject)了一个服务,我正在尝试从该服务的一个属性创建一个计算属性。但是,除非在调试中,否则这始终是未定义的。importEmberfrom'ember';exportdefaultEmber.Component.extend({progress:0,game:Ember.inject.service(),events:this.get("game.challenges")});this怎么能在上面的代码中没有定义呢?它如何不绑定(bind)任何范围?我已经投入了这样的调

javascript - arguments 属性可以通过 this.some_function.arguments 访问吗?其实我无法解释?

我在读一本JavaScript书,我在读如何通过原型(prototype)扩展JavaScript数组的数组功能,然后我来到这个我无法理解的例子,也没有对它进行深入的解释,我不是能够理解:Array.prototype.some_function=function(){varargs=this.some_function.arguments;//1varargs_length=this.some_function.arguments.length;//2...}//some_function在这里我能够访问参数,但我不知道这是如何工作的,意思是this指的是我们调用此方法的对象(在此上

javascript - 了解 Javascript 的 _this、不同类型的函数调用以及如何在函数内部调用函数?

我正在学习如何对现有的javascript代码进行逆向工程,并且遇到了一些问题,这是由于我不了解核心javascript的工作原理。下面是代码以及我的评论的屏幕截图。代码以声明varwarper开始。然后warper变量等于函数内的函数?为什么它不是通常调用的functionWarper(),而是在另一个函数中?我注意到了_this的使用。这与通常使用的常规this有何不同?#btn-submitid被设置为在点击时激活。我可以看到它调用了click_submit函数,但为什么它是Warper.prototype.click_submit而不是click_submit()?我的最后一个

javascript - 未捕获的 TypeError : this. 方法不是函数 - Node js 类导出

这个问题在这里已经有了答案:Howtoaccessthecorrect`this`insideacallback(13个答案)关闭5年前。我是node.js的新手,我正在尝试要求一个类。我用过https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Classes作为引用。但是,当我这样做时://talker.jsclassTalker{talk(msg){console.log(this.say(msg))vart=setTimeout(this.talk,5000,'helloagain');}say(msg){r