多次Ajax请求出现滞后问题解决(切换歌曲)

我在使用django框架开发网站时,通过触发html的点击事件,从而进行ajax请求,让后台播放音乐

但是存在一个问题,每个音乐名称点击使用的是同一个ajax方法请求,我想切换歌曲时,必须等待上一次ajax的返回结束,但是播放歌曲总是会滞后很久才可以返回。

我想了用多线程进行,还是不行,因为开启多线程播放音乐,还是得等待线程事件结束,ajax才能得到返回。所以最终我想了一个方法

定时中断ajax请求:给Ajax添加timeout属性,超时就自动中断请求

 $.ajax({
				url:'/play/?timestamp='+ Math.random(12),
				type:'POST',
                timeout:3000, //3 second timeout
				data:{
					csrfmiddlewaretoken: '{{ csrf_token }}'//重要的一行,缺漏会post forbidden

				},
				dataType:'json',
                success:function (data) {
                    
                    console.log("数据返回");
                }
                        }).fail(function (result,result1,result2) {
                                
                            console.error('error')
                                // console.error(result)
                                // console.error(result1)
                                // console.error(result2)
                            });

这样我的后台还是可以继续播放音乐,而Ajax请求也可以按时结束,我可以随意切换播放音乐

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值