草庐IT

array_replace

全部标签

javascript - 试图监视(Jasmine)Array.prototype 方法导致堆栈溢出

这很奇怪。将testemrunner与jasmine2一起使用并执行以下规范(尽管它正确地标记了没有期望):describe('Spyingonarray.prototypemethods',function(){it('shouldworkthisway',function(){spyOn(Array.prototype,'push').and.callThrough();//expect(1).toBe(1);});});但是,添加一个expect(任何expect!)它会导致堆栈溢出,并在testem控制台中显示以下消息:RangeError:超出最大调用堆栈大小。在http:/

javascript - AngularJS 指令属性 : Replace deprecated - Equivalent?

所以AngularJs正在弃用Replace指令的属性。reference上下文:.directive('myDir',function($compile){return{restrict:'E',template:'{{title}}'}});这将输出:sometitle所以,Replace将取代与template.现在有什么等价物?还是只是将指令与restrict:'A'一起使用?.我创建了这个:.directive('myDir',function($compile){return{restrict:'E',template:'{{title}}',link:link};func

javascript - JavaScript 中 new Array() 的未定义值

查看一些javascript代码,我看到了(类似于)这个:vararr=Array.apply(null,{length:10});阅读Function.prototype.apply()的MDN文档,我了解到虽然它通常需要一个数组作为它的第二个参数,这是一个要传递给调用函数的参数数组,youcanalsouseanykindofobjectwhichisarray-like,soinpracticethismeansit'sgoingtohaveapropertylengthandintegerpropertiesintherange(0...length).据我所知,它调用Arra

javascript - 为什么 [array].concat() 和 [array].concat.apply() 给出不同的输出?

下面的代码,console.log([].concat.apply([2],[[99],5,6,[2,3]]));输出[2,99,5,6,2,3]下面的代码,console.log([2].concat([99]).concat([5,6,[2,3]]));输出[2,99,5,6,[2,3]]我的假设是的输出console.log([].concat.apply([2],[[99],5,6,[2,3]]));应该是[2,[99],5,6,[2,3]]但不是,为什么? 最佳答案 那是因为:console.log([].concat.a

javascript - Array.prototype.forEach() 在使用 get 处理程序的代理上调用时不起作用

我有以下代理:constp=newProxy({[Symbol.iterator]:Array.prototype.values,forEach:Array.prototype.forEach,},{get(target,property){if(property==='0')return'one';if(property==='1')return'two';if(property==='length')return2;returnReflect.get(target,property);},});它是一个类似数组的对象,因为它具有数字属性和指定元素数量的length属性。我可以使用f

javascript - IE 替代 Array.prototype.find()

这个问题在这里已经有了答案:Array.prototype.find()isundefined(3个答案)关闭5年前。我之前编写了一些代码,将上传的文件与其相关的clientID相匹配,并将它们显示在一个表格中以显示哪些文件被分配给了哪些客户端。问题是我根据工作规范在Chrome和Safari上测试了这个并且它工作正常。问题是这在IE上不起作用,因为它不支持Array.prototype.find(),他们现在要求它与IE兼容。我看过其他问题,但答案是针对他们的具体情况的,通常会举例说明其他方法来完成他们正在寻找的事情。实现我想要做的事情的最佳方式是什么?varitem=clientL

javascript - 为什么我不能使用 array == [] 检查数组是否为空?

这是一个来自CodeWars的问题,名为“Countofpositives/sumofnegatives”。它说:Iftheinputarrayisemptyornull,returnanemptyarray为了检查数组是否为空,我决定检查它是否为空数组。当我尝试这样做时:if(input==[])我没有通过测试,但如果我通过了:if(input.length==0)我通过了测试。空数组应该等于[]对吗?为什么会有差异,这两种检查有什么区别?我的代码如下:functioncountPositivesSumNegatives(input){vara=0;varb=0;if(input==

如果像 substring() 那样在 startIndex 和 endIndex 之间找到字符串,则 JavaScript replace()

我的DOM中有一些HTML,我想替换其中的一些字符串,但前提是尚未替换或不是TAG。所有这些都基于一个数组,该数组包含我要查找的字符串和我希望用其替换的新字符串。正在进行的工作:https://jsfiddle.net/u2Lyaab1/23/更新:HTML标记只是为了简单起见在示例代码中使用UL编写,但它可以包含不同的标签、事件不同的嵌套级别基本上desiredReplcement工作得很好(除了它也在标签中查找),但我希望它发生在DOM上,而不是新字符串上,因为我想在DOM.片段:varlist=[{original:'Thisis',new:'Newthisis'},{origi

javascript - TypeError : Array. 来自不是一个函数

我正在关注Angular.iodocumenation使用Angular2编写一个简单的“HelloWorld”应用程序。一旦应用程序在浏览器中运行,Angular2就会从angular2/src/browser_adapter.js中抛出一个TypeError。一切似乎都已正确设置。知道问题是什么吗?控制台:TypeError:Array.fromisnotafunctionatcreateArrayFromMap(http://localhost:3000/node_modules/angular2/src/facade/collection.js:61:42)atFunction

javascript - 如何使用 Array.prototype.filter 过滤对象?

给定vararr=[1,2,true,4,{"abc":123},6,7,{"def":456},9,[10]]我们可以使用Number构造函数过滤数组arr中的数字项varres=arr.filter(Number);//[1,2,true,4,6,7,9,Array[1]]true和[10]应该在结果数组中吗?如果我们在arr处将false替换为truevararr=[1,2,false,4,{"abc":123},6,7,{"def":456},9,[10]]varres=arr.filter(Number)//[1,2,4,6,7,9,Array[1]]使用Array.isAr