` 等父元素上,则该父元素下的所有表单均可被忽略渲染。 |
渲染
`form.render(type, filter);`
- 参数 `type` 可选,对应表单组件类型,支持:`input,select,checkbox,radio`;若不填,则指向所有类型。
- 参数 `filter` 可选,对应 `class="layui-form"` 所在元素的 `lay-filter` 属性值,用于指定需渲染的表单区域。
### **常规渲染**
`form` 组件会在元素加载完毕后,自动对所有表单区域完成一次渲染,因此该方法主要用于对*动态插入*的表单元素的渲染。
```
```
### **定向渲染**
2.7+
该方法还允许指定表单元素的 jQuery 对象,从而完成定向渲染。且支持两种方式的指向:
- 若 jQuery 对象指向表单域容器(`class="layui-form"`),则渲染该表单域中的所有表单项;
2.8+
- 若 jQuery 对象指向的不是表单域容器,则只对该对象进行渲染
定向渲染在页面出现大量表单时,可以极大地减少表单组件渲染时的性能开销,建议灵活运用。
```
```
### **忽略渲染**
若表单域中的部分表单不需要 Layui 来渲染,那么可通过 `lay-ignore` 属性让其保留系统原始 UI 风格。
验证
Layui 对表单验证做了巧妙的支持,只需在表单元素上设置 `lay-verify=""` 属性值即可指定验证规则,如:
```
```
注:上述代码指定的均为内置的验证规则,具体可参考:[#属性介绍](#attr)
自定义验证规则
`form.verify(obj);`
- 参数 `obj` 是一个对象,用于定义验证规则的集合。
除了内置的验证规则外,form 还允许自定义验证规则,规则以函数命名,返回的参数如下:
```
// 自定义验证规则
form.verify({
rule: function(value, elem) {
console.log(value); // 当前进入验证的表单项的值
console.log(elem); // 当前进入验证的表单项的 DOM 元素
}
});
```
在自定义规则中,可根据规则函数返回的 value 自行判断是否必填,如:
```
form.verify({
// 必填项
rule1: function(value, elem) {
// 自定义规则
if (value.length < 6) {
return '不能小于 6 个字符';
}
},
// 非必填项,只有当值填写时才验证自定义规则
rule2: function(value, elem) {
if (!value) return; // 若值未填写,不进行后续规则验证
// 自定义规则
if (/^[A-Z]/.test(value)) {
return '必须用大写字符开头';
}
},
// 自定义提示方式
rule3: function(value, elem) {
// 自定义规则和自定义提示方式
if(value === 'xxx'){
alert('用户名不能为敏感词'); // 此处以系统自带的 alert 提示方式为例
return true; // 返回 true 即可阻止 form 默认的提示风格
}
}
});
```
以下是一个自定义验证规则的示例:
更多「自定义验证规则」示例参考:
> -
将 form 提示语显示在表单项旁边,并在提交时批量触发验证
主动触发验证 2.7+
`form.validate(elem);`
- 参数 `elem` 为元素选择器或 jQuery 对象; 若验证通过,该方法将返回 true,否则返回 false
赋值/取值
`form.val(filter, obj);`
- 参数 `filter` 为表单域容器(`class="layui-form"`)的 `lay-filter` 属性值
- 参数 `obj` 可选。若参数存在,则对表单域进行赋值;若参数不存在,则为对表单域进行取值。
提交
表单的提交可以通过事件触发或方法触发
### **提交事件**
在表单域中,对指定按钮设置 `lay-submit` 属性,即意味着点击该按钮时,将触发提交事件。如:
### **提交方法**
2.7+
`form.submit(filter, callback);`
- 参数 `filter` 为表单域容器的 `lay-filter` 属性值
- 参数 `callback` 为执行提交事件后的回调函数
使用该方法可以实现在任意位置对指定表单的主动提交,相比上述的提交事件更加灵活。
事件
`form.on('event(filter)', callback);`
- 参数 `event(filter)` 是一个特定结构。`event` 为事件名,支持:`select,checkbox,switch,radio,submit`;`filter` 为元素属性 `lay-filter` 对应的值,若不填,则指向所有同类组件的事件。
- 参数 `callback` 为事件执行时的回调函数,并返回一个包含各种值的 `object` 类型的参数。
如下以 `select` 事件为例:
```
// 指向所有 select 组件的选择事件
form.on('select', function(data){
console.log(data);
});
// 指向元素为 `
` 的选择事件
form.on('select(test)', function(data){
console.log(data);
});
```
全局设置
`form.set(options);`
- 参数 `options` : 全局属性选项。详见下表:
| 属性名 | 描述 | 类型 | 默认值 |
| --- | --- | --- | --- |
| autocomplete | 设置 input 框的 `autocomplete` 属性初始值 | string | - |
该方法用于对 form 组件进行全局设置。
```
form.set({
autocomplete: 'off' // 阻止 input 框默认的自动输入完成功能
});
```