layui 验证表单方法

2025-10-29 17:51:31

1、layui本身内置了很多验证方法,只需要按照它的规则预设元素属性,就可以做到一些基本的验证。layui中预设lay-verify来提供验证,基本验证包含:

required(必填项)

 

phone(手机号)

 

email(邮箱)

 

url(网址)

 

number(数字)

 

date(日期)

 

identity(身份证)

layui 验证表单方法

2、在页面中声明元素,并使用预设元素属性设置验证,lay-verify中可以配置多个验证,多个验证之间用|来分开。注意,声明的元素必须要放在form中。

<input name="name" placeholder="请输入姓名" type="text" class="layui-input" lay-verify="required|phone" />

layui 验证表单方法

3、编写form的提交验证事件,该方法需要采用layui提供的内置编写方法,语法:form.on('event(过滤器值)', callback); 具体代码如下:

layui.use(['layer', 'form', 'admin', 'laydate', 'ax'], function () {

 

   var $ = layui.jquery;

 

   var $ax = layui.ax;

 

   var form = layui.form;

 

   var admin = layui.admin;

 

   var laydate = layui.laydate;

 

   var layer = layui.layer;

 

   // 表单提交事件

 

   form.on('submit(btnSubmit)', function (data) {

 

       var ajax = new $ax(Feng.ctxPath + "/idm/mgr/edit", function (data) {

 

           Feng.success("修改成功!")

 

           //关掉对话框

 

           admin.closeThisDialog();

 

       }, function (data) {

 

           Feng.error("修改成功!" + data.responseJSON.message)

 

       });

 

       ajax.set(data.field);

 

       ajax.start();

 

   });

 

});

layui 验证表单方法

layui 验证表单方法

4、当然,layui内置的方法,在某些情况下,是满足不了验证需求的,这时,就需要使用到layui的自定义验证。可以自定义验证规则,通常对于比较复杂的校验。我们可以通过下面的方式,来添加自定义验证规则:

form.verify({

username: function(value, item){ //value:表单的值、item:表单的DOM对象

if(!new RegExp("^[a-zA-Z0-9_\u4e00-\u9fa5\\s·]+$").test(value)){

return '用户名不能有特殊字符';

}

if(/(^\_)|(\__)|(\_+$)/.test(value)){

return '用户名首尾不能出现下划线\'_\'';

}

if(/^\d+\d+\d$/.test(value)){

return '用户名不能全为数字';

}

}

//我们既支持上述函数式的方式,也支持下述数组的形式

//数组的两个值分别代表:[正则匹配、匹配不符时的提示文字]

,pass: [

/^[\S]{6,12}$/

,'密码必须6到12位,且不能出现空格'

]

});

layui 验证表单方法

5、对于自定义验证规则,我们调用的方式和内置规则一样,直接在预设元素属性lay-verify中直接添加,layui的form会自动识别。通过图片,可以看到自定义的验证规则启用了。

<input name="password" placeholder="请输入密码" type="password" class="layui-input" lay-verify="required|psw"/>

layui 验证表单方法

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢