草庐IT

my_class_instance_var

全部标签

javascript - 为什么 let 不比 var 慢?

做一个极端的总结,thedifferencebetweenvarandlet他们的生活在一个范围内。因此,如果我们要以thisanswer中的示例为例:(function(){for(vari=0;ii(用var声明)存在于整个function中j(用let声明)只存在于for循环中。对我来说,这意味着javascript,在每次迭代之后,除了声明和分配给变量之外,在let的情况下,它还需要执行一个额外的步骤:清理j但如果我正在阅读thespecs对了,还有很多:对于var,执行以下步骤:IterationStatement:for(Expressionopt;Expressionop

javascript - 剧情 js : how to run my javascript ONLY after plot image is loaded

当通过JavascriptAPI(plotly.js,而不是plotly-nodejs)使用任何类型的plotly图表时,我如何才能在图表加载后运行一些javascript?我正在寻找plotlyjavascriptAPI中的机制,例如,在使用GoogleMapsAPI时,它与“addListenerOnce”结合“tilesloaded”或“ready”执行相同的操作。例如,假设我想在呈现https://plot.ly/~PlotBot/685处显示的示例后立即简单地显示一个警报,其html和js代码可以在https://plot.ly/~PlotBot/685.js查看.这样做的原

javascript - 激活元素的 :active CSS pseudo-class using Javascript?

这可能吗?例如,如果用户按下“return”键并且我触发了“mousedown”事件,我该如何渲染带有:active样式的元素?我知道可以使用类来做到这一点,但我更愿意使用预先存在的:active样式。 最佳答案 根据CSS2.1spec,:active伪类适用于:anelementisbeingactivatedbytheuser.Forexample,betweenthetimestheuserpressesthemousebuttonandreleasesit.您应该能够以主题元素作为事件目标来调度mousedown事件,并且

javascript - 为什么这个被屏蔽的 JS 代码在 GET 参数 : '*alert(13)*' executed on my page?

我们对我们的网站进行了白帽扫描,他们返回的漏洞之一是我们的URL附加了whscheck'*alert(13)*'a/。当我们运行完整的URL(https://oursite.com/phorders3/index.php/whscheck'*alert(13)*'a/)时,网站会加载并发出带有值的警报13流行音乐。谁能解释这是如何工作的?星号和a/到底在做什么? 最佳答案 您页面中的代码在Javascript的字符串文字中使用URL中的值,而没有正确转义该值。这意味着任何人都可以将Javascript放在URL中,它就会在页面中执行

javascript - 如何根据 Class 而不是 Id 进行 Google 音译

我正在做一个基于泰米尔语的Web应用程序。在我的应用程序中,我使用动态字段来添加用户详细信息。那么,动态字段有多个ID如何做到这一点或如何使用基于类的Google音译?//LoadtheGoogleTransliterationAPIgoogle.load("elements","1",{packages:"transliteration"});functiononLoad(){varoptions={sourceLanguage:'en',destinationLanguage:'ta',shortcutKey:'ctrl+m',transliterationEnabled:true

JavaScript 本地作用域 : var vs. this

我似乎无法理解JavaScript变量作用域的特定情况。与我发现的其他示例和问题不同,我对嵌套函数的范围界定很感兴趣。我在thisJSFiddle设置了一个示例.相关部分如下:functionMyObject(){varself=this;vara=1;this.b=2;varinnerMethod=function(){//1and2:directreferencelogMessage("a="+a);//a=1//logMessage("b="+b);//Error:bisnotdefined//3and4:usingthislogMessage("this.a="+this.a)

JavaScript 'class' 和单例问题

我有一个使用另一个对象(不是单例)的单例对象,需要一些信息给服务器:varsingleton=(function(){/*_privateproperties*/varmyRequestManager=newRequestManager(params,//callbacksfunction(){previewRender(response);},function(){previewError();});/*_publicmethods*/return{/*makearequest*/previewRequest:function(request){myRequestManager.re

javascript - try/catch 表达式中的 var 关键字 : JSLint bug or global assignment?

我注意到JSLint的一个有趣结果在研究codereview题。JSLint提示变量在定义之前被使用。这是生成相同结果的代码的缩短版本:(function(){try{vara=0;throw{name:"fakeError"};}catch(e){a=1;}}());我对JavaScript的理解是上面的代码应该等同于:(function(){vara;try{a=0;throw{name:"fakeError"};}catch(e){a=1;}}());事实上,当通过Firebug运行时,这两个示例都不会导致a存在于全局范围内。我看了一下ECMA-262spec的第12.14节,但

javascript - 在 Backbone.js 中,如何让模型父类(super class)默认值充当子类的默认值?

我有一个定义了一些默认值的类和一个定义了一些默认值的子类。但是当我创建子类的实例时,它只查看本地默认值,不会将其默认值与父类的默认值合并。有什么简单的方法可以做到这一点,而无需在每个子类的initialize函数中显式地将本地默认值与父默认值合并?varInventory=Backbone.Model.extend({defaults:{cat:3,dog:5}});varExtendedInventory=Inventory.extend({defaults:{rabbit:25}});varei=newExtendedInventory({});console.log(ei.att

javascript - 在嵌套函数中使用 var 声明一个与 parent 参数同名的变量

我正在使用JavaScript编写一些代码并发现了意外行为。我在f中使用嵌套函数g。f有一个名为m的参数。在g中使用和声明同名变量时,会发生一些奇怪的事情:varf=function(m){varg=function(){alert(m);varm=0;};g();};f(1);此代码将导致undefined,而不是我预期的1。将alert语句移动到var行下方会得到有意义的答案0。我想这是因为JavaScript仅将函数用作名称闭包,varm将通过声明附加到函数g,但是m在alert时尚未分配。但我不确定这一点,因为如果函数没有嵌套,我觉得它的行为很好:varg=function(m