ajax长连接没有反应,ajax实现服务器与浏览器长连接的功能

有时候,需要服务器主动给浏览器推送数据,这里用ajax来实现这种功能,具体请看这里:

var uid = "{$uid}";

var i = 0;

var timer;

$().ready(function(){

//打开扫码登录模态框

$('#login').click(function(){

//如果用户已经登录,则返回

if(uid){

return ;

}

//打开模态框,通过remote选项从远程加载数据

$('#loginModel').modal({

remote: "{:U('user/login')}"

});

});

//模态框隐藏之后清空数据

$("#loginModel").on("hidden.bs.modal", function() {

$(this).removeData("bs.modal");

});

//当模态框显示出来后,通过定时返回来向服务器请求数据,定时器是每三秒请求一次服务器

$('#loginModel').on('shown.bs.modal', function (e) {

timer = setInterval(ajax_request, 3000);

});

});

//ajax 请求函数,

function ajax_request(){

i++;

//如果已经请求20此没有请求成功,则强制结束,给出提示信息,因为每3s调用一次,供调用20次,大概就是一分钟的时间

if(i > 20){

$('.login_info1').html('登录超时,如需登录请刷新页面~');

clearInterval(timer);

return ;

}

$.ajax({

type: "post",

url: "{:U('User/login_qrcode')}",

timeout : 3000,

data: { "scene_id": $('#scene_id').val() },

success: function (msg){

if(1 == msg.status){

$('.login_info1').html(''+msg.info+'');

setTimeout(refresh, 3000);

return ;

}

},

error: function(){

}

});

}

//重载页面

function refresh(){

location.reload();

}

以上就是本文的全部内容,希望对大家的学习有所帮助。

时间: 2016-04-10

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值