分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

jQuery Ajax(异步改同步)

发布时间:2023-09-06 02:18责任编辑:胡小海关键词:jQueryAjax

在实际使用中,我们经常会用的Ajax(异步加载,在不刷新整个网页的前提下对网页部分内容进行更新)

使用时,偶尔会遇上需要从一个接口中得到一个数组和数据对应的id,在另一个接口上再得到数据,最初写法如下:

$.get(url_1, function (data) { ???????var dom = []; ???????for (var i = 0; i < data.length; i++) { ???????????var item = data[i]; ???????????????????????//两个url不一致,根据id查找另一个表 ???????????$.get(url_2, function (data) { ???????????????var item_result = data; ???????????????dom.push("<div> item_result.id</div>"); ???????????????}); ??????????????????} ???????$("#id").empty().append(dom.join(‘‘)); ?????????});

但是此时经常会出现数组清空后并没有写入数据的问题,初学时常误以为时接口错误的问题,其实不然

这是由于$get()等Ajax方法在调用接口时需要时间,导致push还未完成已经发生了append的行为,即此时数组清空,但是dom数组中此时并没有join读取的数据

故此处需要将循环中的Ajax修改为同步,代码修改如下:

$.get(url_1, function (data) { ???????var dom = []; ???????for (var i = 0; i < data.length; i++) { ???????????var item = data[i]; ???????????????????????//在第二次的Ajax前将异步改同步 ???????????$.ajaxSettings.async = false; ???????????//两个url不一致,根据id查找另一个表 ???????????$.get(url_2, function (data) { ???????????????var item_result = data; ???????????????dom.push("<div> item_result.id</div>"); ???????????????}); ??????????????????????//注意在ajax中的push完成后,将其改回异步 ???????????$.ajaxSettings.async = true; ???????} ???????$("#id").empty().append(dom.join(‘‘)); ?????????}); ???????????

jQuery Ajax(异步改同步)

原文地址:https://www.cnblogs.com/cyuanwu/p/9782329.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved