草庐IT

while语句

全部标签

javascript - Handlebars.js - 在每个循环、if 语句和子对象中获取父上下文

我了解如何在Handlebars中横穿数据源,但我偶然发现了一种我无法解决的情况。使用“../”您可以到达父模板范围,但是当遍历对象的子对象时,它似乎返回对象而不是子对象。{{#eachcontent.items}}{{#ifprop}}{{prop}}+{{../../variable}}{{/if}}{{/each}}如果您遍历一个名为“content”的对象,上面的代码片段可以正常工作,但是一旦您遍历它的子对象“content.items”,它就不再返回正确的范围。这是一个演示问题的fiddle。http://jsfiddle.net/sidonaldson/MDdn2/任何人都

javascript - 当循环遍历 JS 数组的值并删除值时,是否需要使用 while 而不是 for?

varmyArray=[1,2,3,4,5,6,7,8,9];functionisOdd(value){returnvalue%2;}for(vari=0;i上面的代码采用任意长度的数组并检查每个值。如果数组位的值满足任意条件(在本例中为奇数),则将其从数组中移除。Array.prototype.splice()用于从数组中删除值,然后递减i以说明数组中的其余值“向下移动”以填补删除值留下的空白(因此循环不会跳过值)。但是,当i等于数组的长度时,for循环结束,随着值的删除,数组长度变短。myArray.length的值是随着循环的进行而动态减少,还是它在循环开始时保存值而不是在值被删

javascript - 为什么在使用 && 时 IF 语句中有两个 !!?

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Whatisthe!!(notnot)operatorinJavaScript?我正在查看一些代码,看到一个IF语句,如下所示。谁能告诉我为什么有两个!!而不是一个?我以前从未见过这个,也无法在谷歌上挖掘任何东西,因为它忽略了特殊字符。if(!!myDiv&&myDiv.className=='visible'){}

javascript - javascript 中无表达式语句的完整形式是什么?

这个问题在这里已经有了答案:Detectinganundefinedobjectproperty(50个答案)关闭8年前。Javascript从C中采用了一种语法,您可以在其中执行逻辑检查,而无需检查任何内容:if(foo){}这相当于什么?是吗:if(foo!=null){}if(foo!==null){}if(typeof(foo)!='undefined'){}if(typeof(foo)!=='undefined'){}if(typeof(foo)!='object'){}if(typeof(foo)!=='Object'){}我问的实际动机是想确保一个成员“存在”(也就是说,

javascript - 将 "if/then..else"语句与 "switch"语句组合

我必须并排显示两个数字(都以zero.gif文件开始)。每个数字都需要一个输入区域供用户输入1到5之间的数字和一个显示“处理编号”的按钮,然后相应的数字就会弹出。我必须对一个使用if-then-else语句,对另一个使用switch语句。我分别了解这两者,但我不确定如何在脚本代码中将两者结合起来。目前,当我在第一个输入框中输入一个数字时,两者同时变化。如果我尝试第二个框,我会收到警告“您必须选择1到5之间的数字。”所以我不确定如何将两者分开。我使用了不同的图像ID,但它不起作用。这是所有代码。functionprocessNumber(){varnumberInput=document

javascript - 为什么 eval 不能访问 with 语句下的作用域变量?

为什么您不能在with语句下使用eval访问作用域变量?例如:(function(obj){with(obj){console.log(a);//printsoutobj.aeval("console.log(a)");//ReferenceError:aisnotdefined}})({a:"hello"})编辑:正如知识渊博的CMS所指出的,这似乎是一个浏览器错误(使用WebKit控制台的浏览器)。如果有人想知道我试图想出什么可憎的东西需要“邪恶的”eval和with--我想看看我是否可以让一个函数(用作回调)在另一个上下文中执行,而不是在它定义的上下文中执行。不,我可能(咳嗽)不

javascript - if 语句中的逗号

我在一些JavaScript中遇到过一个相当令人困惑的语句:if(n="value",a==b){...我认为这是先给n赋值,然后比较(a==b)判断是否继续if声明。但为什么?这样做比说...有什么好处吗?n="value";if(a==b){...或者...if(a==b){n="value";... 最佳答案 在JavaScript中,无论何时将多个表达式放在一对括号内,它们都会被计算为最后一个表达式,如下例所示:vara=(1,2);varb=a+1;//b=2+1=3因此,在您的情况下,解释器执行属性n="value",然

javascript - 为什么 JavaScript 语句 "ga = ga || []"有效?

如果未声明ga,以下javascript语句将导致错误。if(ga){alert(ga);}错误是:gaisnotdefined看起来未声明的变量无法在bool表达式中识别。那么,为什么下面的语句有效?varga=ga||[];对我来说,ga被视为“||”之前的bool值。如果为false,"||"后的表达式分配给最终ga。 最佳答案 null或defined是javascript中的假值(隐式计算为假。)||运算符返回第一个不计算为false的值。varx=0||""||null||"hello"||false;//xequals

javascript - return语句全局变量后的函数声明不被覆盖

这个问题在这里已经有了答案:Javascriptfunctionscopingandhoisting(18个答案)关闭2年前。我有如下Javascript代码,http://jsfiddle.net/ramchiranjeevi/63uML/varfoo=1;functionbar(){foo=10;return;functionfoo(){}}bar();console.log(foo);//returns1当代码执行时,调用bar()函数并用值10覆盖全局变量,那么日志应该打印为10而不是打印为值1。

javascript - 生成 DOM 元素时替代 JavaScript `with` 语句

比如说,我有一个JavaScript库来生成如下所示的DOM片段AheadingAparagraph其中库domlib具有适用于任何类型元素的方法,生成上述片段的函数可能如下所示:function(domlib){returndomlib.main(domlib.h1('Aheading'),domlib.p('Aparagraph'));}在此函数中,我更愿意像这样调用domlib方法:main(h1('Aheading'),p('Aparagraph'))为此,我可以将domlib的所有方法放在全局范围内,但我宁愿避免污染全局范围。在我看来,with语句似乎是一个理想的解决方案:f