多次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请求也可以按时结束,我可以随意切换播放音乐


版权声明:本文为hahahahanhanhan原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。