报错:数组明明有内容但打印的length是0,学会使用 async 和 await 解决问题

news2024/12/26 10:51:29

文章目录

    • 一、问题
    • 二、分析
    • 三、解决
      • 1.将异步改为同步
      • 2.设置延迟

一、问题

在日常开发中,for 循环遍历调用接口,并将接口返回的值进行拼接,即push到一个新的数组中,但是在for循环内部是可以拿到这个新的数组,而for循环外这个新的数组时空,打印的长度也是0
在这里插入图片描述

二、分析

因为我们拼接的数据是从接口请求的,而接口请求发送的ajax请求是异步的,因此遇到这种情况,基本上都是一点,你的数组数据来源是异步请求产生的(例如 ajax/axios ),就比如你在ajax的success回调中没有直接使用这个数据,而是赋予了一个全局变量,你此时在ajax的下方打印这个全局变量,便会出现上面的数组有值而长度为0的状况

如此现象呢就是因为你的异步请求还在请求过程中,但是你的代码已经走到了打印那一行,全局变量是个空数组没赋值,我们打印的是这个变量的引用地址,异步赋值之后,因为是地址引用,那个数组已经被修改了。那个时候的数组长度确实还是0。但这个数组包含修改后的数据。

三、解决

1.将异步改为同步

//利用 async和await
async function(){
      await axios.post('') 
    }
methods:{
    // trace接口
    async serveDistanceMethods(param){
      try{        
        const response = await axios.get(`/serveapi/TRACE?LON_START=${param.LON_START}&LAT_START=${param.LAT_START}&LON_END=${param.LON_END}&LAT_END=${param.LAT_END}`);
        const data = response.data;
        // 在这里处理返回的数据
        this.tempList2.push(data);
      }catch (error) {
        // 处理错误情况
        console.error(error);
        this.$message({
          message: "数据错误",
          type: "error",
          showClose: true,
        });
        this.loading = false;
        this.$store.commit("tools/setlonlat", []);
      }
    },



    // 调用
    async handleCalc(){
      this.loading = true;
      // 在下次请求计算之前清除所有实体
      window.viewer.entities.removeAll()
      this.tempList2 = [];
      this.tempList3 = [];
      this.tempList4 = [];
      var temp1 = [];
      // 点击生成的坐标信息(两点以上)
      if(this.lonlat.length>1){
        var result = [];
        for (let i = 0; i < this.lonlat.length-1; i++) {
          result.push([this.lonlat[i], this.lonlat[i + 1]]);            
        }
        // 多个点进行返回值渲染
        for (let index = 0; index < result.length; index++) {
          const element = result[index];
          const tempData = {
            LON_START: element[0][1],
            LAT_START: element[0][0],
            LON_END: element[1][1],
            LAT_END: element[1][0],
          }
          if (this.tracegraph == 'trace') {
            await this.serveDistanceMethods(tempData);
          }
        }
      }
   }
   this.$store.commit("tools/setresultData", this.tempList2);
}

2.设置延迟

setTimeout(() => {
		//代码
	}, 1000);  //1秒后执行代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1000011.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

“投资教父”熊晓鸽老了,IDG光环不再

作者 | 鸠白 艺馨 排版 | Cathy 监制 | Yoda 出品 | 不二研究 2017年&#xff0c;世界互联网大会上&#xff0c;“投资教父”熊晓鸽问映客的创始人&#xff1a;“今年你们利润能有多少&#xff1f;” 对方笑答&#xff1a;“5个亿吧&#xff01;” “才五个亿&#xff1f…

产品MC动画宣传片制作团队安排

在产品MC动画宣传片的制作过程中&#xff0c;通常需要组建一个专业的团队&#xff0c;以确保各个方面的工作能够高效完成。以下是一个常见的产品MC动画宣传片制作团队的安排&#xff1a; 1.制片人&#xff08;Producer&#xff09;&#xff1a;负责项目的整体策划和管理&#…

华为云云耀云服务器L实例评测|有关华为云云耀云服务器L实例你可能不知道的事情

前言 最近华为云推出了华为云云耀云服务器L实例。主打一个轻量级云服务器&#xff0c;即开即用&#xff0c;轻松运维&#xff0c;开启简单上云第一步。具有智能不卡顿&#xff0c;价优随心用&#xff0c;上手更简单&#xff0c;管理特省心。 在推出的第一时间我就买了一台来耍…

H5移动端选择器,layPicker移动端日期选择器,jquery移动端自定义选择器

前言 基于jquery实现的&#xff0c;H5移动端选择器 默认自带日期选择&#xff0c;可自定义选择&#xff0c;和自定义html 效果图 微信模拟版 旧版 使用方式简单 layPicker.init({elem: #year, // 绑定元素options: year, // 设置为日期选择器&#xff08;日期选择器可设…

芯科蓝牙BG27开发笔记2-调试第一个程序

soc-Blinky程序去掉bootloader功能之后就可以下载运行了&#xff0c;但是时不时会在连接的时候死机&#xff0c;进入debug&#xff0c;发现&#xff1a; 查代码&#xff0c;该函数被注册到io stream中&#xff0c;但它是在app.c中调用app_log时实际调用&#xff0c;例如&#x…

bug总结问题集和知识点集

目录 一 bug问题集1. 端口被占用 二 oracle1. oracle查看版本怎么操作2. oracle数据库&#xff1a;参数个数无效![在这里插入图片描述](https://img-blog.csdnimg.cn/6a2eebc164f9406c81525371893bbd11.png) 三 mybatis1. mybatis用注解如何实现模糊查询 四 List1. 如何判断Jav…

Kubernetes 部署发布镜像(cubefile:0.4.0)

目录 实验&#xff1a;部署发布镜像&#xff08;cubefile:0.4.0&#xff09; 需求分析&#xff1a; 1、部署Kubenetes环境&#xff1a; 2、撰写 cubefile-deployment.yaml 文件 代码解释&#xff1a; 遇到的问题&#xff1a; 问题解决 &#xff1a; 3、撰写 cubefile-se…

SSL证书验签时要带www吗?

单域名证书&#xff1a;顶级域名如www.abc.com或abc.com 不管你提交订单的时候填写的域名是带www或不带www的域名&#xff0c;签发的证书均支持www和不带www的域名 单域名证书&#xff1a;子域名如mail.abc.com&#xff0c;签发的证书仅支持mail.abc.com 通配符证书&#xff…

LeetCode 50题:实现Pow(x,n)

题目 实现 pow(x, n) &#xff0c;即计算 x 的整数 n 次幂函数&#xff08;即&#xff0c;xn &#xff09;。 示例 1&#xff1a; 输入&#xff1a;x 2.00000, n 10 输出&#xff1a;1024.00000示例 2&#xff1a; 输入&#xff1a;x 2.10000, n 3 输出&#xff1a;9.26…

你知道SOLIDWORKS焊件类零件有个快速草图建立工具吗?

背景&#xff1a; 焊件是SOLIDWORKS中一个重要的组成模块&#xff0c;通过该模块可以很快的建立起一个庞大的型材结构网络。 但是我们也明白焊件是基于草图的&#xff0c;普通的方式建立复杂的草图是需要较多的精力和时间&#xff0c;本次视频的出发点就是针对此问题给出的一个…

Python网页请求超时如何解决

在进行网络爬虫项目时&#xff0c;我们经常需要发送大量的请求来获取所需的数据。然而&#xff0c;由于网络环境的不稳定性&#xff0c;请求可能会因为超时而失败。请求超时可能导致数据获取不完整&#xff0c;影响爬虫的效率和准确性。此外&#xff0c;频繁的请求超时可能会被…

一个或多个筛选器启动失败。完整的详细信息将在相应的容器日志文件中找到

网上找了好久没解决 问题代码: 11-Sep-2023 16:47:22.109 严重 [RMI TCP Connection(3)-127.0.0.1] org.apache.catalina.core.StandardContext.startInternal 一个或多个筛选器启动失败。完整的详细信息将在相应的容器日志文件中找到 11-Sep-2023 16:47:22.109 严重 [RMI TCP…

二叉树题目:二叉树的层平均值

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法一思路和算法代码复杂度分析 解法二思路和算法代码复杂度分析 题目 标题和出处 标题&#xff1a;二叉树的层平均值 出处&#xff1a;637. 二叉树的层平均值 难度 4 级 题目描述 要求 给定一个二叉树的根结点 …

新人白嫖:基于揽睿星舟云部署Stable Diffusion,10 分钟体验 SDXL 1.0 超强功能(AI绘画保姆级教程)

一、前言 SDXL 1.0 自推出到现在&#xff0c;已经有一段时间了&#xff0c;网上也看到了用 SDXL 做出的各种惊艳的图&#xff0c;相对于 Stable Diffusion 之前的版本来说&#xff0c;功能确实强大了很多。 SDXL 1.0 给我们带来最大的好处就是&#xff0c;基本可以实现靠嘴出图…

Openlayers 教程 - feature(图形要素)三种悬浮事件(移入移出)以及适用范围

Openlayers 教程 - feature&#xff08;图形要素&#xff09;两种悬浮事件以及使用范围 核心代码完整代码&#xff1a;在线示例 之前介绍了 Openlayers 的点击事件&#xff0c;这次介绍一下悬浮事件。 悬浮事件和点击事件还是有区别的&#xff1a;一般点击事件是一次事件&…

element plus表格合并行

/*** 合并相同数据&#xff0c;导出合并列所需的方法(只适合el-table)*/ export function getRowSpanMethod(data, rowSpanArray) {/*** 要合并列的数据*/const rowSpanNumObject {};//初始化 rowSpanNumObjectrowSpanArray.map((item) > {rowSpanNumObject[item] new Arr…

Informatica使用操作流程--聚合、表达式转换、查找、排序组件的使用 案例3

一、需求&#xff1a; 将oracle数据库的scott用户源表items 直抽至 EDW层 EDW_items。数据存储到oracle的edw01用户下 数据抽取至EDW层做聚合转换 求各供应商 min(price),avg(price),max(price),sum(price), 2*avg(price) 根据供应商id去供应商表查找供应商名称 查验…

【Java核心知识】idea项目编译错误排查思路

文章目录 idea项目编译错误排查思路一个项目是如何运行的项目编译报错时排查常见思路 idea项目编译错误排查思路 一个项目是如何运行的 在开始之前&#xff0c;我们需要知道idea对一个项目是如何维护和运行的&#xff1f;idea会把用户自定义配置放在.idea文件夹中&#xff0c…

LeetCode:2. 两数之和

这个解题思路来自代码随想录&#xff1a;代码随想录 (programmercarl.com) class Solution { public:vector<int> twoSum(vector<int>& nums, int target) {std::unordered_map <int,int> map;for(int i 0; i < nums.size(); i) {// 遍历当前元素&am…

ME21N 采购订单屏幕增强

1、业务需求 采购订单行项目新增“图号”和“价格类型”字段。其中图号只查询底表展示&#xff0c;不做修改&#xff1b;价格类型做下拉框&#xff1b; 2、增强实现 增强标准表EKPO结构CI_EKPODB。抬头增加字段则修改EKKO结构CI_EKKODB 增强点CMOD&#xff1a;MM06E005 出口…