JQuery的ajax函数执行失败,alert函数弹框一闪而过

原因其实非常简单,把form表单里最后提交按钮type="submit"换为type="button"

因为这个原因浪费了挺久时间,甚至把代码又从头到尾写了一遍(感觉自己好蠢啊!),总结了一下调试过程。

先贴一下ajax代码:

        $(function () {
            $("#register").on('click',function () {
                $.ajax({
                    type: 'post',
                    url:"{:url('insert')}",
                    data:$('#login').serialize(),
                    dataType:'json',
                    success:function (data) {
                        alert('成功');
                    },
                    error:function () {
                        alert('error');
                    }
                })
            })
        });

这里‘#register’是提交按钮,‘#login’是表单,url发送到一个php脚本(插入表单数据到数据库)。

用谷歌浏览器打开页面,点击注册按钮后,当前页面刷新,没有任何反应。

正常情况下,ajax执行正确或失败,根据上述代码都应该有消息弹窗,于是感觉到哪里出了问题。

打开数据库,发现表单的数据都已经插入到数据库了,说明后台php脚本是运行成功的,只是在返回数据的时候出现了问题。

但是返回数据一般都是json格式,而且我也已经更改。

更换了Edge浏览器,问题同样是数据库插入了数据,但是结果没有消息弹窗。

更换火狐浏览器,再次点击注册按钮时出现了消息弹窗,但是闪了一下就没了!隐隐约约发现弹窗显示为‘error’(感谢火狐浏览器!)

根据alert弹窗一闪而过这个线索,发现了解决问题的这篇文章,同时感谢这篇文章的博主。

参考:关于layer的提示框,弹出框一闪而过的问题

猜你喜欢

转载自www.cnblogs.com/sfriend/p/10676193.html