【JavaScript 之迭代方法】教程文章相关的互联网学习教程文章

在Javascript中迭代一次映射和排序?【代码】

是否可以将数组映射到新数组并同时对其进行排序而不进行两次迭代(一次用于第一个数组上的映射,一次用于第二个数组上的排序)?在使用这样的map方法时,我一直在尝试使用匿名函数对其进行排序:var arr=[4,2,20,44,6]; var arr2=arr.map(function(item, index, array){if(index==array.length-1 || item==array[index+1]){return item;}else if((item-array[index+1])<0){return item;}else if((item-array[index+1])>0){return array...

javascript – 如何正确迭代结构【代码】

我想迭代找到的结构,但我不知道最好的方法是什么. 我试过这个:for (var ext in creep.room.find(FIND_MY_STRUCTURES, {filter: { structureType: STRUCTURE_EXTENSION }})){console.log(ext.energy); }但它不起作用. 所以现在我正在使用一种有效的方法,但它看起来很难看:for(var i = 0; i < creep.room.find(FIND_MY_STRUCTURES, {filter: { structureType: STRUCTURE_EXTENSION }}).length; i++) {var ext = creep.room.find(FI...

javascript – 迭代多个Meteor集合【代码】

我想迭代meteor(服务器端)中的多个Mongo集合.首先,我想检查一个集合是否有任何文件. 我的代码到目前为止:var isEmptyCollection = function(name) {if(name.find().count() === 0) {return true} else {return false}};var mycollections = ["CollectionOne", "CollectionTwo", "CollectionThree"];for (var i = 0; i < mycollections.length; i++) {if (isEmptyCollection(mycollections[i])) {} else {var data = mycollections...

Javascript表排序运行良好,但迭代所有索引会产生不同的结果【代码】

我有一个表,我正在使用以下函数进行排序:function ReorderSupplyGP(table){table.find('tr:not(.kn-table_summary)').sort(function (a, b) {var tda = $(a).find('td:eq(1)').text().trim();var tdb = $(b).find('td:eq(1)').text().trim();var sales = {"Purchase": 0, "Transfer": 1, "Returns": 2, "Adjustment": 3, "Inventory": 4};tda = sales[tda];tdb = sales[tdb]; // if a < b return 1return tda > tdb ? 1// else if...

如何在javascript中的迭代器生成器中实现递归遍历?【代码】

假设我在javascript中有一棵树,如下所示:let rootNode = {name:'', children:[{name:'0', children:[{name:'00', children:[]},{name:'01', children:[{name:'010', children:[]},]},{name:'02', children:[]},]},{name:'1', children:[{name:'10', children:[]},]},]};我想对它进行前序遍历,我可以这样做:function preOrderTraversalRecursive(rootNode, visitNodeCallback) {function recurse(node) {visitNodeCallback(node);...

为什么通过Object.defineProperty添加的属性在Javascript中不可迭代【代码】

考虑以下代码:var a = {get aa() {return 'aa';} };Object.defineProperty(a,'bb',{get: function() {return 'bb';}} );for(p in a) {sys.puts(p + ': ' + a[p]); }输出是:aa: aa但是,物业bb是完全可访问和工作. 为什么’bb’在for..in循环中不可见?解决方法:你必须将enumerable设置为true. (您也可以尝试getOwnPropertyNames(),但我不确定是如何跨浏览器.)var a = {get aa() {return 'aa';} }, arr = [];Object.defineProperty...

javascript – 将递归算法转换为迭代算法的困难【代码】

我一直在尝试在javascript中实现递归回溯迷宫生成算法.这些是在阅读了关于主题here的大量帖子后完成的 虽然算法的递归版本没什么问题,但iterative equivalent让我感到难过. 我以为我理解了这个概念,但是我的实现显然产生了不正确的结果.我一直试图找出一个可能导致它的错误,但我开始相信我的问题是由逻辑失败引起的,但当然我没有看到. 我对迭代算法的理解如下: >创建一个包含单元状态表示的堆栈.>每个表示保存特定单元格的坐标,以...

javascript – 迭代对象时获取TypeError【代码】

我正在使用Rails,我的jQuery代码中出现错误:Uncaught TypeError: Cannot read property 'length' of undefined我收到错误的实际代码:// args is for internal usage onlyeach: function( obj, callback, args ) {var value,i = 0,length = obj.length,isArray = isArraylike( obj );if ( args ) {if ( isArray ) {for ( ; i < length; i++ ) {value = callback.apply( obj[ i ], args );if ( value === false ) {break;}}} else ...

javascript – 迭代jquery对象返回字符串而不是dom元素【代码】

我有以下循环:for(var myScreen in wizardScreens){if(step==index)$(myScreen).show();else $(myScreen).hide();index++; }wizardScreens定义为$(“.wizardScreen”,wizard);,其中wizard是一个DOM元素.在循环中,myScreen设置为字符串,而不是DOM元素.任何人都可以解释为什么会这样吗?解决方法:jQuery集合已经有了内置的迭代函数:wizardscreens.each(function (index, screen) {if (index == step)$(screen).show();else$(screen...

javascript – 使用document.getElementsByTagName迭代dom元素,将元素作为jquery对象传递【代码】

我需要的是在某个start元素处迭代dom,然后遍历start元素下面的所有元素. 这是我到目前为止所做的.function iterDomFromStartElem = function(startElem, callBackFunc) {if (startElem !== null) {var items = startElem.getElementsByTagName("*");for (var i = 0; i < items.length; i++) {callBackFunc(items[i]);}} }我需要从一些start元素迭代dom的原因是因为我们的团队最近收到了实现字体大小调整的请求;但是,我们使用像素在...

如何在使用JavaScript的n次迭代中避免for-if-else地狱【代码】

例如,我有这个代码:var Foo = [1,2,3,4];function searchInFoo(n) {for(var i = 0, arrayLength = Foo.length; i < arrayLength; i++) {if(Foo[i] === n) {console.log("N: " + n + " found!");} else {console.log("N: " + n + " not found!");}} }searchInFoo(4);好吧,正如我所预期的那样,我有一个带有n个元素的Foo数组,我也有n次迭代的for循环.这很酷.所以,如果我用任何n参数调用searchInFoo函数,我的函数也将执行if else语句中...

javascript – AngularJS在ng-repeat中的当前迭代中定位元素【代码】

我确信这个问题已经以这种或那种形式多次回答,但是我不确定要搜索什么来找到解决方案. 假设我们有一个简单的ng-repeat:<div ng-repeat="item in items"><input type="text" value="{{item.name}}"><a ng-click="getTxtBoxVal(whatDoIPassInHere)">Get Text Box Value</a> </div>在javaScript文件中:function $scope.getTxtBoxVal(val) {alert(val)}基本上我想知道whatDoIPassInHere参数应该传递什么,在jquery中会是这样的:$(thi...

.每个函数JavaScript在XML中迭代两次【代码】

我试图用jquery迭代xml并将其发布在html上.由于某种原因,作者中的每个函数都附加了重复项.例如,我将获得James McgovernPer BothnerKurt BothernerKurt CagleJames Linn Valiyanathan Nagarjan,James McgovernPer BothnerKurt BothernerKurt CagleJames Linn Valiyanathan Nagarjan.我想知道如何解决这个问题?谢谢!<book category="web"> <title lang="en">XQuery Kick Start</title> <author>James McGovern</author> <author>Pe...

javascript – jquery – 每次迭代的.each()增加超时间隔【代码】

我想在元素列表上触发动画,并且每次迭代都会延迟一点.我到目前为止已经完成了我的工作: JS Fiddlevar timer = 1000;$('div').each(function(){setTimeout(function(){$('div').animate({width:200,height:200,opacity:1}, 1000);}, timer);timer += 1000; });没有任何错误,它在技术上有效,但它们同时具有动画效果.我知道它与similar code非常相似(几乎完全相同),但由于某种原因,它不起作用.我错过了什么?解决方法:您可以使用inde...

javascript – 在迭代到循环的下一次迭代之前完成FOR LOOP中的所有函数【代码】

说我有一个像这样的功能:var bigArray = [1,2,3,4,5.........n]; for(var i=0; i<bigArray.length; i++){if(someCondition){setTimeout(function(){..do_stuff..callSomeFunction();}, someDelayTime);}if(someCondition){setTimeout(function(){..do_stuff..callSomeFunction();}, someDelayTime);}if(someCondition){setTimeout(function(){..do_stuff..callSomeFunction();}, someDelayTime);}........if(someCondition){setTi...

JAVASCRIPT - 技术教程分类
JavaScript 教程 JavaScript 简介 JavaScript 用法 JavaScript Chrome 中运行 JavaScript 输出 JavaScript 语法 JavaScript 语句 JavaScript 注释 JavaScript 变量 JavaScript 数据类型 JavaScript 对象 JavaScript 函数 JavaScript 作用域 JavaScript 事件 JavaScript 字符串 JavaScript 运算符 JavaScript 比较 JavaScript 条件语句 JavaScript switch 语句 JavaScript for 循环 JavaScript while 循环 JavaScript break 和 continue 语... JavaScript typeof JavaScript 类型转换 JavaScript 正则表达式 JavaScript 错误 JavaScript 调试 JavaScript 变量提升 JavaScript 严格模式 JavaScript 使用误区 JavaScript 表单 JavaScript 表单验证 JavaScript 验证 API JavaScript 保留关键字 JavaScript this JavaScript let 和 const JavaScript JSON JavaScript void JavaScript 异步编程 JavaScript Promise JavaScript 代码规范 JavaScript 函数定义 JavaScript 函数参数 JavaScript 函数调用 JavaScript 闭包 DOM 简介 DOM HTML DOM CSS DOM 事件 DOM EventListener DOM 元素 HTMLCollection 对象 NodeList 对象 JavaScript 对象 JavaScript prototype JavaScript Number 对象 JavaScript String JavaScript Date(日期) JavaScript Array(数组) JavaScript Boolean(布尔) JavaScript Math(算数) JavaScript RegExp 对象 JavaScript Window JavaScript Window Location JavaScript Navigator JavaScript 弹窗 JavaScript 计时事件 JavaScript Cookie JavaScript 库 JavaScript 实例 JavaScript 对象实例 JavaScript 浏览器对象实例 JavaScript HTML DOM 实例 JavaScript 总结 JavaScript 对象 HTML DOM 对象 JavaScript 异步编程 javascript 全部