layui 表单提交不执行ajax的坑

在官方文档2.x里面写的layui Form提交示例,form.on事件获取表单对应的json信息,然后自己ajax提交表单,

但是总是提交失败,一开始以为获取到json信息之后的那个return false已经无用了。没想到就这个return 坑了我好一会。

如果要提交ajax请求必须要在form.on事件的结尾加上return false。 记录一下,下面是代码。

这个页面的前提是引入了相关的css和js

<link rel="stylesheet" href="jqueryplugin/layer/src/layui.css">
<link rel="stylesheet" href="jqueryplugin/layui/src/css/layui.css">

<script src='jqueryplugin/layer/dist/layer.js' type='text/javascript'></script>
<script src='jqueryplugin/layui/src/layui.js' type='text/javascript'></script>

layer和layui两个都引入了,然后表单的最后给的一个按钮事件

<div class="layui-form-item">
            <div class="layui-input-block">
                <button class="layui-btn" lay-submit lay-filter="updateUser">修改</button>
            </div>
        </div>

 下面是js

layui.use('form', function() {
            var form = layui.form;

            //自定义验证规则
            form.verify({
                userName : function(value) {
                    if (value.length < 2||value.length>6) {
                        return '请写正确填写姓名';
                    }
                },
                pass : [ /(.+){6,12}$/, '密码必须6到12位' ],
//                 money : [ /^\d+\.\b\d{2}\b$/, '金额必须为小数保留两位' ]
            });

            //监听提交
            form.on('submit(updateUser)', function(data) {
                console.log(typeof data);
                console.log(data.field);
//                 return false;                
                $.ajax({
                    contentType : "application/x-www-form-urlencoded; charset=utf-8",
                    type : "post",
                    url : htmlVal.htmlUrl + "?doEditUser=",
                    data : data.field,
                    dataType:'json',
                    success : function(res) {
                        isTimeOut(res);
                        if (res.errorCode == '0') {
                            layer.alert('更改成功', function(index) {
                                location.reload();
                                layer.close(index);
                            })
                        }
                        if (res.errorCode == 'loginName') {
                            layer.alert('登录名已存在!', function(index) {
                                layer.close(index);
                                return false;
                            })
                        }
                        if (res.errorCode == 'email') {
                            layer.alert('email已存在!', function(index) {
                                layer.close(index);
                                return false;
                            })
                        }
                        if (res.errorCode == 'cellphone') {
                            layer.alert('手机号码已存在!', function(index) {
                                layer.close(index);
                                return false;
                            })
                        }
                        if (res.errorCode == 'wrong_email') {
                            layer.alert('email格式错误!', function(index) {
                                layer.close(index);
                                return false;
                            })
                        }
                        if (res.errorCode == 'wrong_cellphone') {
                            layer.alert('手机号码格式错误!', function(index) {
                                layer.close(index);
                                return false;
                            })
                        }
                    }
                });
                //这个return非常重要,防止ajax跳转,去掉的话就不经过ajax了
                return false;
            });

        });

 

转载于:https://www.cnblogs.com/dayu007/p/9528290.html

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果layui不使用ajax,可以考虑使用表单提交的方式进行登录,然后在后台服务器接收到表单提交的请求后,处理完成后再返回响应,响应中可以包含状态码和响应体。在前端页面中,可以通过表单的submit()方法来提交表单,然后在后续处理中,通过解析响应来判断登录是否成功。可以使用JavaScript中的XMLHttpRequest对象或者fetch()方法来发送表单请求并接收响应。对于状态码和响应体的获取,可以通过XMLHttpRequest对象的status属性和responseText属性,或者fetch()方法返回的Promise对象进行处理。 ### 回答2: 在layui中,如果不使用ajax请求,想要捕获HTTP响应中的状态码和响应体来判断登录是否成功,可以使用layuiform模块来实现。 首先,在HTML页面中,将登录表单放置在一个form标签中,并设置其id属性为"login-form",且设置action属性为登录请求的URL。在form标签中,可以添加一些input标签用于输入用户名和密码。 然后,在JavaScript代码中,使用layuiform模块进行表单监听和提交操作。在form的监听回调函数中,可以获取表单的数据,然后可以使用laySubmit()方法进行提交。 接下来,可以在form的监听回调函数中,使用jQuery的ajax方法来进行登录请求的发送,并设置success回调函数来处理登录成功的逻辑。在success回调函数中,可以获取到服务器返回的响应数据,包括状态码和响应体。 最后,根据返回的状态码和响应体,可以判断登录是否成功。如果状态码为200且响应体中包含某个特定的字段或值,就可以认为登录成功。可以使用if语句对返回的数据进行判断,然后执行相应的逻辑。 总结起来,即通过layuiform模块监听表单提交事件,使用jQuery的ajax方法发送登录请求并获取返回的响应数据,根据返回的状态码和响应体判断登录是否成功。如果成功,可以执行相应的操作,如果失败,可以给出相应的提示信息。 ### 回答3: 在layui中,如果不使用Ajax来发送登录请求,我们可以使用layuiform模块来实现捕获HTTP响应中的状态码和响应体,从而判断登录是否成功。 首先,我们可以在登录表单中添加一个隐藏的div元素,用于存储登录结果。例如: ```html <div id="loginResult" style="display:none;"></div> ``` 然后,在登录按钮的点击事件中,通过form模块的on('submit')方法,获取登录表单的数据,并将其提交给后端。同时,可以通过jQuery的ajax方法来发送请求,获取HTTP响应。 ```javascript layui.use(['form', 'jquery'], function(){ var form = layui.form; var $ = layui.jquery; form.on('submit(loginBtn)', function(data){ var postData = data.field; // 获取登录表单数据 $.ajax({ url: 'login.php', // 登录请求地址 type: 'POST', data: postData, success: function(response){ $("#loginResult").html(response); // 将响应结果存储到隐藏的div中 // 在这里可以根据不同的状态码和响应体内容来判断登录是否成功 var statusCode = response.statusCode; // 可以通过解析响应体的json数据来获取状态码 var msg = response.msg; // 可以通过解析响应体的json数据来获取提示信息 if (statusCode == 200) { layer.msg(msg); // 登录成功,显示成功提示 // 其他登录成功后的操作 } else { layer.msg(msg, {icon: 5}); // 登录失败,显示失败提示 } } }); return false; // 阻止表单的默认提交行为 }); }); ``` 在成功收到响应后,我们可以根据不同的状态码和响应体内容来判断登录是否成功。如果登录成功,我们可以显示成功提示并进行其他登录成功后的操作;如果登录失败,我们可以显示失败提示。 通过以上步骤,我们可以在不使用Ajax的情况下,通过form模块和隐藏的div元素来捕获HTTP响应中的状态码和响应体,从而判断登录是否成功。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值