草庐IT

my_function_with_global_var

全部标签

javascript - 如何在 JS 的 setTimeout 中调用 this.function?

我有以下JS:functionTrackTime(){this.CountBack=function(secs){setTimeout(function(){this.CountBack(secs)},SetTimeOutPeriod);}}我已经用闭包(见上文)和其他十几种方法尝试过这个。我似乎无法在任何浏览器中使用它。setTimeout函数在未在“类”函数中调用时工作正常。有人可以帮我吗? 最佳答案 发生这种情况是因为执行函数时“this”的范围发生了变化。试试这个技巧..functionTrackTime(){this.Co

javascript - javascript 关联数组中的属性名称 "var"

出于好奇的快速提问:下面的代码在Firefox和Chrome中有效,但在Safari中无效。Firefox和Chrome规避了这个Javascript规范,还是Safari中的一个怪癖?vara={};a.var="test";全部(firefox、safari和chrome)a["var"]="test";a.id="anothertest";按预期工作。干杯,杰伦。 最佳答案 var是保留关键字,因此在不加引号的情况下使用它可能会中断。 关于javascript-javascript

javascript - jQuery/JavaScript : My recursive setTimeout function speeds up when tab becomes inactive

我在构建的这个jQuery幻灯片插件中遇到了一个奇怪的小困境。这没什么特别的,我迄今为止编写的代码运行良好,但我注意到,当我离开网站运行并切换到新选项卡并继续在另一个选项卡中浏览网页时(Mac版Chrome在我的例子中),当我返回我的站点时,setTimeout调用似乎已经加速,而不是等待计时器完成触发事件,而是连续触发。这是我的(简化)代码:vartimer;varcounter;varslides;//collectionofalltargetedslides.//animatetothenextslidefunctionnextSlide(){//stoptimermethods

javascript - “var” 变量、"this"变量和 "global"变量 - 在 JavaScript 构造函数中

在我上一个问题之后,这个问题对我来说更准确:例子:functionFoo(){this.bla=1;varblabla=10;blablabla=100;this.getblabla=function(){returnblabla;//exposesblablaoutside}}foo=newFoo();我现在的理解:this.bla=1;//willbecomeanattributeofeveryinstanceofFOO.varblabla=10;//willbecomealocalvariableofFoo(will**not**becomeanattributeofeveryi

javascript - 语法 !function() { ... } 是什么意思?

我在简单、伟大、精彩和强大的库中找到了这个语法knockoutjs:!function(factory){...}function声明前的非符号(!)是什么意思?更新:源代码不再包含这个确切的语法。 最佳答案 !运算符表现正常,否定表达式。在这种情况下,它用于强制函数成为函数表达式而不是函数语句。由于!运算符必须应用于表达式(将其应用于语句是没有意义的,因为语句没有值),该函数将被解释为表达式。这样可以立即执行。function(){alert("foo");}();//errorsincethisfunctionisastatem

javascript - JS Globalize - 加载 json cldr

我对最新版本的globalize.js有疑问。要使用它,我必须加载cldr模块和语言定义。现在我从全局化文档中得到了这个例子://loadingneededmodules$.get('/Scripts/cldr/supplemental/likelySubtags.json',Globalize.load);$.get('/Scripts/cldr/main/en/numbers.json',Globalize.load);$.get('/Scripts/cldr/main/de/numbers.json',Globalize.load);//setcurrentlanguagelob

javascript - 为什么 let 语句的行为与 var 如此不同?

我知道let是声明block作用域局部变量,但为什么它不像var那样支持重新声明和提升?这个限制的设计目的是什么?(function(){'usestrict';alert(a);//undefinedvara;})();(function(){'usestrict';alert(a);//errorleta;})();(function(){'usestrict';vara;vara;alert(a);//undefined})();(function(){'usestrict';leta;leta;//erroralert(a);})(); 最佳答案

javascript - Firebase promise - Query.once 失败 : Was called with 1 argument. 预计至少 2

我正在尝试使用promises将来自Firebase的一些数据填充到一个数组中。这是数据库结构:-domainname(orsomething)|--highscore|--Foo:50|--Bar:60代码:vararr=[];highscoreRef.child('highscore').once('value').then(function(snapshot){snapshot.forEach(function(data){arr.push({playerName:data.key(),score:data.val()});});},function(error){console

javascript - 如何将 fingerprint2 结果存储在 var 中

我打算将fingerprint2结果存储在一个var中。varinfo={};newFingerprint2().get(function(result,components){info.fingerprint=result;});alert(info.fingerprint);但没用有没有更好的方法,比如:varfp=newFingerprint2().get();还是一些增强的方法?编辑:现代且灵活的浏览器指纹识别库,原始fingerprintjs的继承者http://valve.github.io/fingerprintjs2/用法:newFingerprint2().get(f

Javascript:不使用 var 关键字时有两个输出

GoogleChrome和Firebug为我提供了这个示例的两个不同输出。如果b是全局的,那么第一个应该给我undefined第二个14。对吗?但在Firebug中,它给出了两个14,而Chrome给出了引用错误。functiona(){b=14;}console.log(b);a();console.log(b); 最佳答案 不要使用浏览器控制台进行范围实验。不同的浏览器控制台以不同的方式运行您的代码。如果您在正常环境中完全按照引用的方式运行该代码,正确的是您将从第一个console.log(b)中得到一个ReferenceErr