4

我正在尝试在表单提交之前验证用户的互联网连接,以便我的 JavaScript 验证函数可以引发警报并在没有连接时返回 false。

我试过:navigator.onLine - 在 FF 中不起作用(只查看浏览器是否处于“离线模式”)

对我自己网站的 AJAX 请求:

$.ajax({  
  type: "GET",  
  url: "internet_test.php",  
  async: false, //trying to force a response before continuing
  timeout:8000,
  success: function(ret_text) {
    if(ret_text == 'yes') {
      return true;
    } else {
      alert("No Connection 1");
      return false;
    }
  },
  error: function(x, t, m) {
    if(t==="timeout") {
      alert("No Connection 2");
      return false;
    } else {
      alert("No Connection 3");  //this is the one triggered
      return false;
    }
  }
});

我收到了第三种错误的警报,但是表单还是提交了。我猜这个错误覆盖了我试图指定同步检查的事实,并且 JavaScript 验证器在 AJAX 可以返回 false 之前完成。

有没有解决这个问题的好方法?更好的方法?

谢谢!

4

1 回答 1

2

我会这样:

  1. 将“提交”更改为“按钮”(或链接)-它将停止提交表单。
  2. 单击此按钮进行 AJAX 调用,如果一切正常,则进行 form.submit();

这只是一个草稿,一切都可以变得更加用户友好,对于无 js 浏览器等更强大。

于 2013-03-08T22:01:39.640 回答