jq--ajax中止请求

比如我后端设置延迟3s再响应给前端,我用的是node之koa2

router.get('/vueDemo/getStudents', async ( ctx ) => {
    //延迟3s
    async function delay(time) {
        return new Promise(function(resolve, reject) {
            setTimeout(function(){
                resolve();
            }, time);
        });
    };
    await delay(3000);

    //向后断返回数据
    let st = await students.find();
    ctx.response.type = 'application/json';
    ctx.body = st;
})

 

前端设置超时

<script>
        var url='http://localhost:3000/vueDemo/getStudents'
        //发起请求
        var getStudents=$.ajax({
            type: 'get',
            url:url,
            timeout:2000
        })
        getStudents.then(function (rep) {
            console.log(rep)
        },function () {
            //如果超过2s还未回应,中断请求
            console.log('超过2s还未回应,中断请求')
            getStudents.abort()
        })
</script>

 

 

前端设置非超时

<script>
        var url='http://localhost:3000/vueDemo/getStudents'
        //发起请求
        var getStudents=$.ajax({
            type: 'get',
            url:url,
            timeout:5000
        })
        getStudents.then(function (rep) {
            console.log(rep)
        },function () {
            //如果超过2s还未回应,中断请求
            console.log('超过2s还未回应,中断请求')
            getStudents.abort()
        })
</script>

 

转载于:https://www.cnblogs.com/dshvv/p/7784415.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值