草庐IT

BOOL_VAR_H

全部标签

javascript - 什么时候将字符串、数字和 bool 值声明为 Javascript 中的对象是明智的

什么时候应该将Javascript数据类型声明为对象?它们会降低执行速度,并产生严重的副作用,那么为什么这可能呢?根据W3Schools:http://www.w3schools.com/js/js_numbers.asp同样来自http://www.w3schools.com/js/js_datatypes.asp 最佳答案 数字、字符串和bool值既可以是基元也可以是对象。例如,您可以创建一个原始字符串,也可以创建另一个对象:varname='JohnDoe';varemail=newString('john@example.c

Javascript - 当标识符字符串存储在 var 中时访问对象成员

我有一个非常简单的问题(和初步答案),我只是想看看是否有更好的答案。当成员标识符存储在另一个变量中时,如何在javascript中访问对象成员?示例:state='sync';messages={'sync':'asdf','ready':'asdf','complete':'asdf'};可能性:1.message=eval('messages.'+state);将消息转换为散列(在原型(prototype)或jquery中——jquery不确定)并通过框架的方法访问还有哪些方法呢?有没有更干净的?在php中,它很简单$message=$messages->$sync。我确定这个问题

javascript - 是不是写: var arr=[]; than var arr=new Array();?比较好

这个问题在这里已经有了答案:What’sthedifferencebetween"Array()"and"[]"whiledeclaringaJavaScriptarray?(19个回答)Whatisthedifferencebetween`newObject()`andobjectliteralnotation?(12个答案)CreateanemptyobjectinJavaScriptwith{}ornewObject()?(10个答案)关闭5年前。是不是写的比较好vararr=[];thenvararr=newArray();varobj={};thenvarobj=newObj

javascript - Angular 2 中没有默认值的 FormControl bool 值

我在Angular2(4.1.2)中使用react形式我有一个bool属性,我不希望它有一个默认值,但它应该是必需的。这是我创建表单的方式:constructor(privatefb:FormBuilder){this.form=this.fb.group({payedOvertime:[false,Validators.required],});}还有我的html:PayedovertimeYesNo问题是,虽然这有效,但我不想这样,但我不希望这样,而是必须通过单击其中一个单选按钮来选择它。如果没有点击任何单选按钮,我希望表单无效。 最佳答案

javascript - 我什么时候应该使用 `this.x` 与 `var x` ?

在创建JavaScript类函数时,我使用了this。很多。但是在使用它时,我想知道使用var是否会有所不同。varMyClass=function(){this.x=4;return{getVal:this.x};}与var的使用对比:varMyClass=function(){varx=4;return{getVal:x};}有什么区别,什么时候应该使用哪个?同样的问题适用于class语法:classMyClass{constructor(){constx=4;}}对比classMyClass{constructor(){this.x=4;}} 最佳答案

javascript - JavaScript 中的赋值和 var 关键字

我在阅读“学习Node”这本书时遇到了一个非常简单的问题,一个我没有考虑太多的问题:javascript中的赋值。作者声明我们应该意识到通过使用Node的REPL,以下将返回未定义的:vara=2(undefined)而下面的代码将在REPL中返回“2”:a=22这是为什么呢?上面的代码不是属性?怎么会?如果var'a'直到代码中的那个点才存在,为什么它不存在和归属? 最佳答案 根据ECMA-262§12.2,VariableStatement(即varidentifier=value)显式不返回任何内容。此外,VariableSt

javascript - 当 var trees = new Array ("redwood", "bay", "cedar"时 0 如何成为树的属性)

这个问题在这里已经有了答案:Accessnumericpropertiesofanobjectusingdotnotation(2个答案)关闭11个月前。我在mozilla文档中看到了这个例子,但我不明白为什么。如果0是树的属性,我原以为trees.0会返回redwood但这是一个错误的陈述。a[0]是一种访问数组0属性的方法吗?在这种情况下,a["length"]也应该有效(逻辑上)。谁能说清楚?链接:developer.mozilla.orgvartrees=newArray("redwood","bay","cedar","oak","maple");0intrees;//ret

javascript - 为什么结果不同(使用 var 与 let)?

这使用varvara=[];for(vari=0;i这使用letvara=[];for(leti=0;i我不明白为什么结果不同。有人可以指导我吗? 最佳答案 结果数组由函数组成,每个函数体如下所示:console.log(i);i的值取决于我们是使用var还是let来声明变量。var(ECMAScript5和6)这里的i是一个全局变量,退出循环后的值为10。这是记录的值。让(ECMAScript6)这里的i是一个局部变量,它的作用域被限制在for语句中。此外,这个变量在每次迭代时都会得到一个新的绑定(bind)。这最好由您的代码解释

javascript - Chrome 控制台 : difference between 'let' and 'var' ?

我附上了一个动画gif来说明这种奇怪的行为。本质上,我的问题是Chrome控制台在相同范围内使用时是否会区别对待var和let?您会注意到,在声明/分配一个变量后,如果您尝试在控制台中输入该变量的名称,Chrome会自动为您完成它,并显示一个包含您输入的内容的下拉列表。使用let时,情况并非如此。这是错误、功能,还是我遗漏了有关JavaScript中的var和let的内容?注意:我很清楚let在直接范围内生存和死亡。 最佳答案 当您在控制台中使用var时,它会在全局范围内执行并将变量添加到window对象。当您在控制台中使用let时

javascript - 创建 JavaScript bool 变量

deletemode=newBoolean(false);if(deletemode)alert("TRUE");elsealert("FALSE");alert(deletemode);我希望看到FALSE警报,但我看到的是TRUE警报我读了MDN,它读了deletemode=newBoolean(true);这就是创建假bool变量的方法但是当我运行上面的语句时,我看到“TRUE”,然后在第二个警报中我看到false。如果我这样做,它就会按照我的预期去做if(deletemode===false)是if(deletemode)JavaScript语法错误?