点击播放看效果

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport"
  6. content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
  7. <meta http-equiv="X-UA-Compatible" content="ie=edge">
  8. <title>for里面是采用setInterval遍历二维数组,for循环到最后一个数的时候,才执行setInterval的问题解决</title>
  9. </head>
  10. <body>
  11. <button id="play">播放</button>
  12. <script>
  13. var sumPath=[
  14. {
  15. RowKey:"LNBSCB3F2FD11327120190327091134",
  16. point:[
  17. {Longitude: "104.074027",Latitude:"30.707441"},
  18. {Longitude: "104.109422", Latitude: "30.669311"},
  19. {Longitude: "104.108675", Latitude: "30.665402"},
  20. {Longitude: "104.108667", Latitude: "30.665388"}]},
  21. {
  22. RowKey:"LNBSCB3F2FD11327120190327103555",
  23. point:[
  24. {Longitude: "104.113186", Latitude: "30.663265"},
  25. {Longitude: "104.114061", Latitude: "30.663335"},
  26. {Longitude: "104.11468", Latitude: "30.663531"},
  27. {Longitude: "104.115255", Latitude: "30.663612"},
  28. {Longitude: "104.11565", Latitude: "30.663767"}
  29. ]
  30. }];
  31.  
  32. // 怎么按顺序遍历二维数组 ,如果是for里面是一个setInterval,则到for循环到最后一个数的时候,才执行setInterval。 需要用2个setInterval来解决,setInterval是异步的,里面却是同步的
  33. document.getElementById("play").addEventListener("click",function () {
  34. firstTraverse();
  35. });
  36. var firstIndex=0;// 第一层数组的index
  37. var secondIndex=0;// 第二层数组的index
  38. // 第一层的遍历
  39. function firstTraverse () {
  40. var firstInterval=setInterval(function () {
  41. clearInterval(firstInterval);
  42. if(firstIndex<sumPath.length){
  43. var point=sumPath[firstIndex].point;
  44. secondTraverse(point);// 第二层数组传过去
  45. console.log("第一层的index:"+firstIndex);
  46. }
  47. },1000)
  48. }
  49. // 第二层的遍历
  50. function secondTraverse (point) {
  51. var secondInterval=setInterval(function () {
  52. if(secondIndex<point.length){
  53. console.log("第二层的index:"+secondIndex);
  54. drivePath();
  55. }else {
  56. clearInterval(secondInterval);// 要清的是第二个定时器
  57. secondIndex=0;
  58. firstIndex++;
  59. firstTraverse();// 从第一个开始重新调用
  60. return;
  61. }
  62. secondIndex++;
  63. },1000)
  64. }
  65. // 划线
  66. function drivePath() {
  67.  
  68. }
  69. </script>
  70. </body>
  71. </html>

for里面是采用setInterval遍历二维数组,for循环到最后一个数的时候,才执行setInterval的问题解决的更多相关文章

  1. C:指针遍历二维数组

    C 指针遍历二维数组 http://blog.csdn.net/lcxandsfy/article/details/55000033 C++ 字符串指针与字符串数组 https://www.cnblo ...

  2. C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why?

    C/C++遍历二维数组,列优先(column-major)比行优先(row-major)慢,why? 简单粗暴的答案:存在Cache机制! 稍微啰嗦一点:CPU访问内存(读/写,遍历数组的话主要是读) ...

  3. php中遍历二维数组并以表格的形式输出

    一.索引数组 <?php //使用array()语句结构将联系人列表中所有数据声明为一个二维数组,默认下标是顺序数字索引 $contact1 = array( //定义外层数组 array(1, ...

  4. php中foreach循环遍历二维数组

    最近在用tp3.2框架,在查询的时候用到了select(),这条语句返回的是二维数组,所以在对返回的数据做处理时,遇到了些麻烦,百度了下foreach,终于用foreach解决了数据的筛选问题 (因为 ...

  5. ANSI C遍历二维数组指针地址

    #include <stdio.h> int main() { ][] = {,,,}; //等价于{{1,2},{3,4}}; ; i < ; i++) { ; j < ; ...

  6. C++入门经典-例6.11-使用指针变量遍历二维数组

    1:代码如下: // 6.11.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #inc ...

  7. 20130330 printf数组改变 数组指针便利二维数组 二级指针遍历二维数组 ZigZag

    1.为什么printf之后数组的值会改变? #include<stdio.h> ; int * Zigzag() { ,j=,limit=; ; ; int a[N][N]; int (* ...

  8. js 二维数组 for 循环重新赋值

    javascript 二维数组的重新 组装 var arr = [[1,2],[3,4],[5,6],[7,8]]; var temp = new Array(); for(var i= 0 ;i&l ...

  9. PHP中遍历二维数组—以不同形式的输出操作

    <body> <?php //定义二维索引数组$arr = array(    array("101","李军","男", ...

随机推荐

  1. 【原创】大叔问题定位分享(29)datanode启动报错:50020端口被占用

    集群中有一台datanode一直启动报错如下: java.net.BindException: Problem binding to [$server1:50020] java.net.BindExc ...

  2. linux日志过滤某时间段的日志

    sed -n '/2019-01-10 16:00*/,/2019-01-10 18:48*/p' nohup.out > 111.log

  3. Android的路接下来该怎么走?

    其实想写这篇文章好久了,很多小伙伴们也经常在群里探讨android移动开发者的走向,一部分人都想多快好省,间歇性踌躇满志.持续性混吃等死 ,只想用CV的开发模式们快速完成工作,然后回家王者农药.其实这 ...

  4. javascript 路径读取

    //获取当前文件全路径 <script language="javascript"> alert(window.location.href); alert(window ...

  5. Canvas 画占比图 解决canvas锯齿 bug

    案例如图: <section class=" chartWrap"> <div class="chartContent"> <di ...

  6. ubantu/centos修改系统时间

    前言:有时系统上的时间和真实的时间对应不是,或者有特殊需求,需要修改系统时间.但是对应多台的服务器系统更改时间,手动的话很麻烦,这就需要写脚本或者搭建时间服务器了,统一时间,以下是对于一个不同系统修改 ...

  7. 圆周率pi π 与 角度的对应关系

    圆周率pi π 与 角度的对应关系 π 180° π/2 90° π/4     45° π/6     30°

  8. selenium之使用chrome浏览器测试(附chromedriver与chrome的对应关系表)

    https://www.cnblogs.com/JHblogs/p/7699951.html

  9. Android源代码下载 “Gerrit下载源代码”

    repo init -u ssh://jenkins@gerrit.y:29419/manifest -m k86A.xml 使用-m参数指定具体使用的是k86A.mxl文件 步骤1. curl ht ...

  10. 2017-2018 ACM-ICPC Pacific Northwest Regional Contest (Div. 1)

    A. Odd Palindrome 所有回文子串长度都是奇数等价于不存在长度为$2$的偶回文子串,即相邻两个字符都不同. #include<cstdio> #include<cstr ...