报错:为什么数组明明有内容但打印的length是0

文章目录

一、问题

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

二、分析

因为我们拼接的数据是从接口请求的,而接口请求发送的ajax请求是异步的,因此遇到这种情况,基本上都是一点,你的数组数据来源是异步请求产生的(例如 ajax/axios ),就比如你在ajax的success回调中没有直接使用这个数据,而是赋予了一个全局变量,你此时在ajax的下方打印这个全局变量,便会出现上面的数组有值而长度为0的状况
如此现象呢就是因为你的异步请求还在请求过程中,但是你的代码已经走到了打印那一行,全局变量是个空数组没赋值,我们打印的是这个变量的引用地址,异步赋值之后,因为是地址引用,那个数组已经被修改了。那个时候的数组长度确实还是0。但这个数组包含修改后的数据。

三、解决

1.将异步改为同步

js 复制代码
//利用 async和await
async function(){
      await axios.post('') 
    }
js 复制代码
$.ajax({
	url: '',
	data: {},
	dataType: 'json',
	async:true,//同步属性设置为true 
	type: 'post',
	success: function(obj) {

	}
})

2.设置延迟

js 复制代码
setTimeout(() => {
		//代码
	}, 1000);  //1秒后执行代码
相关推荐
Railshiqian9 分钟前
给android源码下的模拟器添加两个后排屏的修改
android·开发语言·javascript
恋猫de小郭1 小时前
Flutter 的真正价值是什么?深度解析再结合鸿蒙,告诉你 Flutter 的真正优势
android·前端·flutter
Ehtan_Zheng2 小时前
我们如何在不减少功能的前提下,将安卓应用体积缩减 60%
android
QING6182 小时前
使用ADB分析CPU性能 —— 基础指南
android·前端·app
大白要努力!2 小时前
Android图片预览功能实战:从需求到上线的完整方案
android·viewpager·图片预览·实战记录·photoview
如此风景5 小时前
kotlin协程学习小计
android·kotlin
轩情吖5 小时前
MySQL初识
android·数据库·sql·mysql·adb·存储引擎
Sun_gentle6 小时前
android studio创建flutter项目
android·flutter·android studio
我命由我123456 小时前
在 Android Studio 中,新建 AIDL 文件按钮是灰色
android·ide·android studio·安卓·android jetpack·android-studio·android runtime
音视频牛哥6 小时前
Android平台RTMP/RTSP超低延迟直播播放器开发详解——基于SmartMediaKit深度实践
android·人工智能·计算机视觉·音视频·rtmp播放器·安卓rtmp播放器·rtmp直播播放器