草庐IT

foo_value

全部标签

javascript - Chai 期待 : an array to contain an object with at least these properties and values

我正在尝试验证像这样的对象数组:[{a:1,b:2,c:3},{a:4,b:5,c:6},...]至少包含一个同时具有{a:1}和{c:3}的对象:我想我可以用chai-things做到这一点,但我不知道对象的所有属性都可以使用expect(array).to.include.something.that.deep.equals({??,a:1,c:3});和contain.a.thing.with.property不适用于多个属性:/测试此类内容的最佳方法是什么? 最佳答案 所需的解决方案似乎是这样的:expect(array).

javascript - `this instanceof String` 和 `"foo"instanceof String` 有什么区别?

我正在像这样扩展对象:Object.prototype.is_a=function(x){returnthisinstanceofx;}一切正常"foo".is_a(String)//true"foo".is_a(Object)//true"foo".is_a(Array)//false"foo".is_a(Function)//false"foo".is_a(Boolean)//false"foo".is_a(Date)//false"foo".is_a(Number)//false"foo".is_a(RegExp)//false但是,当"foo"instanceofString/

javascript - ES6 做 for of get prototype values - 如何检查 hasownproperty

使用for...in我总是检查hasOwnProperty(我想这是使用Object.keys的一个很好的论据),例如:for(letainobj){if(obj.hasOwnProperty(a)){//logic}}当我使用for...of时是否需要做同样的检查?如果需要,我应该怎么做?根据MDNpageonfor...ofWhilefor...initeratesoverpropertynames,for...ofiteratesoverpropertyvalues但是它没有说明该迭代是包含继承属性还是仅包含实例属性。那里给出的解释和示例代码仅涉及实例属性。

javascript : checking boolean values

我在表单中将一个bool值设置为隐藏变量,并且我有以下javascript。$().ready(function(){varflag=$('#popUpFlag').val();alert("flag="+flag);if(flag){alert("flagistrue");}else{alert("flagisfalse");}})这些是警报的输出。flag=flagisfalseflag=falseflagisfalseflag=trueflagisfalse我关心的显然是第三个输出。当标志为true时,为什么打印“flagisfalse”而不是“flagistrue”。我在IE8

javascript - 传入动态 key :value pairs to an object literal?

这个问题在这里已经有了答案:IsitpossibletoadddynamicallynamedpropertiestoJavaScriptobject?(20个答案)关闭6年前。我正在使用这段代码(如下所示)尝试在for循环中填充名为Parameters的对象文字。我需要key:value对与迭代i变量的循环一起分配,例如:{key_1:chunks[1],key_2:chunks[2]}。但是,我的代码不起作用。'key_'+i未反射(reflect)在文字中。显然,我在这里缺少一些东西。谁能告诉我它是什么?...谢谢。varParameters=[];varlen=chunks.l

像 "var foo = function bar() ..."这样的 Javascript 函数?

代码是这样的(语法可能看起来很奇怪,但据我所知,它没有任何问题。或者有什么问题?)varadd=functionaddNums(a,b){returna+b;}alert("add:"+add(2,3));//produces5alert("addNums:"+addNums(2,3));//shouldalsoproduce5addNums()被声明为一个函数。所以,当我将参数传递给它时,它也应该返回结果。那么,为什么我没有收到第二个警告框? 最佳答案 您看到的是namedfunctionexpression(NFE).匿名函数表

javascript - 在 Javascript 中,<int-value> == "<int-value>"的计算结果为 true。为什么会这样?

如果我执行0=="0",它的计算结果为true。试试看,if(-777=="-777")alert("same");警报发生。而且,值得注意的是true=="true"的计算结果不为true。试试看,if(false=="false")alert("same");警报不会发生。为什么会这样? 最佳答案 ==的行为有点冗长,但在ecma-262spec中有明确定义。:11.9.3TheAbstractEqualityComparisonAlgorithmThecomparisonx==y,wherexandyarevalues,pro

javascript - Diamond-Square 实现产生的值(value)太高

我已经实现了一个生成高度图的Diamond-Square函数。乍一看,该实现似乎工作正常。这只是两个示例,但已经可以看出输出值总体上似乎相当高。只有很少的真正黑暗的值(value)观。一世。E.如果您查看此paper中的高度图(由diamondsquare制作)你可以看到它们不像我的那么均匀。不同地区之间有更多的偏移量。有些区域看起来像陨石坑。我无法弄清楚此行为的原因是错误的参数化还是实现。尽管Web上的示例实现确实略有不同,但我认为我已经掌握了基本思路。我正在处理平面类型数组。我传递给函数的参数是:边长因为我有一个表示二维矩阵的平面数组,所以我传递网格边长以进行进一步计算。我在这里传

javascript - .then(functionReference) 和 .then(function(value){return functionReference(value)}) 之间有区别吗?

给定一个用于处理Promise值的命名函数functionhandlePromise(data){//dostuffwith`data`returndata}a)将命名函数handlePromise作为对.then()的引用传递promise.then(handlePromise)b)使用匿名函数或命名函数作为.then()的参数,并以Promise值作为参数返回命名函数handlePromise在传递给.then()的匿名或命名函数的主体内promise.then(function/*[functionName]*/(data){returnhandlePromise(data)})

javascript - 为什么 "foo".toString() 与 toString.call ("foo"不同)?

下面是一个JavaScript问题://TestedviaGoogleChromeconsole.vartoString=Object.prototype.toString;"foo".toString();//"foo"toString.call("foo");//[objectString][].toString();//""toString.call([]);//[objectArray]{}.toString();//syntaxerrortoString.call({});//[objectObject]为什么toString的结果与toString.call()不同?已更新