草庐IT

this_call

全部标签

javascript - 更改 "this"变量的函数

我是JavaScript的新手,正在尝试了解OOP和模拟“类”的一些基础知识。在执行该脚本的最后一行时,我希望第4行调用的this对象指针指向farm对象(就像它在第2行中正确执行的那样,并且3).不幸的是它没有,我猜this对象指针指向document。varBuilding=function(cost){this.cost=cost;this.printCost=function(){document.getElementById(this).innerHTML=this.cost;}}varfarm=newBuilding(50);farm.printCost();-有没有办法让

javascript - this.domNode 为空

我正在尝试使用jquery加载dojo图表。我正在使用这段代码。但是在第二次单击时,在第一个按钮中出现此错误。如果我单击第一个按钮,单击第二个按钮,然后再次单击第一个按钮,也会发生同样的情况。这个问题快把我逼疯了。demohere$(document).ready(function(){$('.lista_').click(function(){$.get('index1.php',function(data){dojo.addOnLoad(function(){require(["dojo/_base/xhr","dojo/parser","dojo/dom"],function(x

javascript - 'this' 在 Javascript 函数中指的是什么

我理解this关键字背后的一般概念,但我很难弄清楚它在实践中实际指的是什么。例如,在这两个示例练习中,我都猜错了数字。对于问题1,我说alert会是'5',因为它指的是函数中匿名函数外的this.x。在问题2中,我认为警报会是5,因为这一行varalertX=o.alertX;会将变量o内属性x的值5绑定(bind)到新变量“alertX”,该变量成为下一行中的函数调用:alertX();你能解释一下为什么我错了吗?varquestion1=function(){this.x=5;(function(){varx=3;this.x=x;})();alert(this.x);};vara

javascript - this.someFunction.call(this, param); 的目的是什么?

我在很多地方都遇到过一些具有这种模式的代码:this.someFunction.call(this,param);但在我看来这只是一种更冗长的打字方式this.someFunction(param)该模式有时会出现在作为回调提供的函数中。如果相关的话,它恰好使用了Backbone。像这样:Backbone.View.extend({//otherstuff...someFunction:function(param){//...},anotherFunction:function(){this.collection.on("some_event",function(){this.som

javascript - 如何在单例模式中保留 javascript "this"上下文?

我有类似的东西:vara=(function(){return{b:1,c:function(){console.log(this.b);}};})();所以,a.c();//=1但如果我这样做b=2;a.c.apply(this);//=2是否有可能在不改变(太多)“a”对象的结构的情况下在“a.c()”中保留“this”的上下文?我无法控制函数的调用,因此我需要一种变通方法来在对象本身内部处理此问题。更新:更具体地说,这是我的文件结构:结构一(类单例模式):vara=(function(){var_instance;functioninit(){return{b:1,c:funct

javascript - Ionic 2 构建开发失败 : Maximum call stack size exceeded

我无法构建我的ionic2应用程序。更改文件后服务有效。在ionic服务上,我收到以下错误消息:[07:36:10]ionic-app-scripts1.0.0[07:36:10]watchstarted...[07:36:10]builddevstarted...[07:36:10]cleanstarted...[07:36:10]cleanfinishedin1ms[07:36:10]copystarted...[07:36:10]transpilestarted...[07:36:15]builddevfailed:Maximumcallstacksizeexceeded[07:

javascript - AngularFirebaseAuth : Calling server api just after firebase auth?

我的身份验证基于两件事:firebase身份验证(电子邮件/密码)调用服务器API以从BDD和firebaseID检索完整的客户实体(用户必须存在)因此,如果满足这两个条件,用户将被“认证”。我还有一个基于返回Observable的isAuthenticated()的authGuard(因为在页面刷新时,守卫必须等待身份验证完成,然后才能将用户重定向到任何地方)。问题:我找不到一种方法让它与所有异步和rxjs困惑/hell一起工作。目前它正在工作,但每次调用isAuthenticated时,都会调用serverAPIauth时间...我怎样才能重构它以便只调用服务器一次并且所有异步/重

javascript - 'this'关键字在原型(prototype)链中是如何工作的?

您好专家,这是我的代码,我对this关键字如何向对象添加属性感到困惑。functioncarMaker(){this.companyName='Lamborghini';}letLamborghiniUrus=newcarMaker();carMaker.prototype.country="Italy"LamborghiniUrus.price="200000";我知道用this和Object.prototype添加的属性会继承给所有对象,但两者是等价的,即this也在添加属性到原型(prototype)?如果是那么为什么console.log(carMaker.prototype.

javascript - "Call stack"和 JavaScript 中的 "Execution context stack"一样吗?

我经常在很多文章中看到“调用堆栈”。像这样:https://hackernoon.com/understanding-js-the-event-loop-959beae3ac40#ec22但是在ECMAScript文档中找不到“调用堆栈”。“调用堆栈”是否与“Executioncontextstack”相同? 最佳答案 СallStack和ExecutionStack是同一事物的不同名称。它是一个LIFO堆栈,用于存储在代码执行期间创建的执行上下文。维基百科说:“这种堆栈也称为执行堆栈、程序堆栈、控制堆栈、运行-时间堆栈,或机器堆栈

javascript - 如何处理 "a script on this page is causing internet explorer to run slowly"警报?

我正在从javascript调用网络方法。在IE中,如果我向该Web方法传递一个巨大的参数,则会弹出警告“停止运行此sciprt?此页面上的脚本导致InternetExplorer运行缓慢”。是否可以处理"is"按钮上的点击,以便如果用户决定取消脚本执行我可以运行一些替代脚本(在这种情况下,我的“替代”脚本包括关闭一些进度条我在运行长时间脚本之前弹出)。我看过很多解释如何防止显示此警报的帖子,但我不想停止显示警报:我只想能够处理用户决定停止显示的情况脚本执行。 最佳答案 我之前在一个内部应用程序中处理过这个问题,他们不关心浏览器处理