快速解决ajax请求出错状态码为0的问题
程序员文章站
2024-01-23 21:11:34
今天在使用 ajax 向后台请求数据时出现错误,提示状态码为 0 ,后台采用的是 spring mvc 架构。
状态码为0是什么意思呢?查找了下,原来它意味着 (未初始化...
今天在使用 ajax 向后台请求数据时出现错误,提示状态码为 0 ,后台采用的是 spring mvc 架构。
状态码为0是什么意思呢?查找了下,原来它意味着 (未初始化)即没有调用到send()方法,我原来代码如下 :
$.ajax({ url:"test", type:"post", data:{ blogtitle : $("#form1 input").val(), blogtype : $("#form1 option:selected").val(), article : htmlcontent }, datatype: "json", success: function(data,textstatus){ if(data.flag == "success"){ alert("发表成功!"); window.location.href = 'http://www.baidu.com'; } }, error: function(xmlhttprequest, textstatus, errorthrown){ alert(xmlhttprequest.status); alert(xmlhttprequest.readystate); alert(textstatus); } });
仔细检查,好像没什么不对劲的啊,况且在后台都能正常接收发送的数据了,说明 ajax 还是发送了数据的,这是后台打印的相关参数信息
又一番思索,原来是表单出现了问题:
<form onsubmit="addblog();"> //中间省略 <button type="submit">发表博客</button> </form>
可以看到,我在 button 标签添加了 type=”submit”属性,但这样做会产生新的一次表单点击提交,本来form 默认点击 button 时会产生一次提交 , button type=”submit” 时又会产生新第一次提交,导致 ajax 未执行完毕表单事件发生了改变。
解决方法: 将上面代码改为:
<form onsubmit="return false"> //中间省略 <button type="addblog()">发表博客</button>
以上这篇快速解决ajax请求出错状态码为0的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。