无任何的设置的情况下,默认使用form标签中action的地址,method就算进行更改也是没有用的,它就是只能用get方法进行请求

解决方法有两种

使用js绑定点击函数来实现异步请求(在js中写updatePassword()函数,用异步请求,可改请求类型);

<button  class="layui-btn"  lay-submit lay-filter="formDemo" onclick="updatePassword()">提交</button>

但是你会发现有一个问题,就是提交后页面自动刷新了,提示一闪而过,原因是触发了layui的js函数,因为如果不将按钮type设置值的,就是默认为submit的类型,所以需要为这个按钮设置type属性为button即可,不然就是相当于触发了form自带的action提交,触发了两次(一次ajax,一次form中action请求)。

<button type="button" class="layui-btn"  lay-submit lay-filter="formDemo" onclick="updatePassword()">提交</button>

其实用这个方法相当于只用layui的界面和非空校验,提交后无论怎么样都不会清空已经填写的内容,如果不想改type的值,就需要重新写触发事件。下面代码就是什么都不干,就是不触发form表单的提交。

form.on('submit(formDemo)', function(data){
  return false;
})

第二种使用layui提供的方法:

这个方法按钮一定要有lay-submit lay-filter="formDemo" 属性,而且不要改type为button,不然找不到的,而且用第二种方法拿值表单属性一定要有class="layui-form"

在写各种请求就可以了,拿数据的方式有很多种
    //一种就是用js设置id,拿各个数据的值,在用ajax进行传输,这个就没有利用上name属性了,这里我采用了第一种              
    //另一种就是利用data.field.name参数拿到form表单的值(这个name就是设置的name属性,是要写你的name值),在进行传输就可以了

var form = layui.form;
form.on('submit(formDemo)', function(data) {//formDemo是按钮的名字,就是lay-filter属性。
    console.log(data)
    if($("#confirmNewPassword").val()             !=""&&$("#newPassword").val()&&$("#oldPassword").val() !=""){
        if($('#confirmNewPassword').val()==$('#newPassword').val()) {
            $.ajax({
                type: 'Put',
                url: '/account/updatePassword',
                dataType:'json',
                data: {
                    type: "student",
                    oldPassword: $("#oldPassword").val(),
                    newPassword: $("#newPassword").val(),
                },
                success: function (res) {
                    if (res.status=="1"){
                        layer.open({
                            title: '更改结果'
                            ,content: '密码更改成功'
                            ,icon: 1
                        });
                    }
                    else {
                        layer.open({
                            title: '更改结果'
                            ,content: '密码更改失败,请检验原始密码是否正确'
                            ,icon: 2
                        });
                    }
                    document.getElementById("reset").click();
                },
                error: function (errMsg) {
                    //todo
                    console.log(errMsg);
                }
            })
        }
        else{
            layer.open({
                title: '警告'
                ,content: '新密码两次必须相同'
                ,icon: 2
            });
        }
    }
    else{
        layer.open({
            title: '警告'
            ,content: '密码不能为空'
            ,icon: 2
        });
    }
    return false;//这个很重要,可以防止页面一闪而过,没有提示信息。
})

Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐