586 lines
19 KiB
Markdown
586 lines
19 KiB
Markdown
::: anchor
|
||
:::
|
||
|
||
::: title 基础使用
|
||
:::
|
||
|
||
::: demo
|
||
|
||
<template>
|
||
<lay-form :model="model">
|
||
<lay-form-item label="账户" prop="username">
|
||
<lay-input v-model="model.username"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="密码" prop="password">
|
||
<lay-input v-model="model.password" type="password"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="爱好" prop="hobby">
|
||
<lay-select v-model="model.hobby">
|
||
<lay-select-option value="1" label="学习"></lay-select-option>
|
||
<lay-select-option value="2" label="编码"></lay-select-option>
|
||
<lay-select-option value="3" label="运动"></lay-select-option>
|
||
</lay-select>
|
||
</lay-form-item>
|
||
<lay-form-item label="特长" prop="specialty">
|
||
<lay-radio v-model="model.specialty" name="specialty" label="1">写作</lay-radio>
|
||
<lay-radio v-model="model.specialty" name="specialty" label="2">画画</lay-radio>
|
||
<lay-radio v-model="model.specialty" name="specialty" label="3">编码</lay-radio>
|
||
</lay-form-item>
|
||
<lay-form-item label="描述" prop="desc">
|
||
<lay-textarea placeholder="请输入描述" v-model="model.desc"></lay-textarea>
|
||
</lay-form-item>
|
||
<lay-form-item>
|
||
<lay-button @click="submitClick">提交</lay-button>
|
||
</lay-form-item>
|
||
</lay-form>
|
||
</template>
|
||
|
||
<script>
|
||
import { ref, reactive } from 'vue'
|
||
import {layer} from '@layui/layer-vue'
|
||
|
||
export default {
|
||
setup() {
|
||
|
||
const model = reactive({
|
||
username: "admin",
|
||
password: "123456",
|
||
specialty: "1"
|
||
})
|
||
|
||
const submitClick = function(){
|
||
layer.open({
|
||
type: 1,
|
||
title:"表单结果",
|
||
content: `<div style="padding: 10px">${JSON.stringify(model)}</div>`,
|
||
shade: false,
|
||
isHtmlFragment: true,
|
||
btn : [{ text: '确认', callback(index) { layer.close(index) }}],
|
||
area : '500px'
|
||
});
|
||
};
|
||
|
||
return {
|
||
model,
|
||
submitClick
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
:::
|
||
|
||
::: title 表单基本校验功能
|
||
:::
|
||
|
||
::: demo
|
||
|
||
<template>
|
||
<lay-form :model="validateModel" ref="layFormRef" required>
|
||
<lay-form-item label="账户" prop="username">
|
||
<lay-input v-model="validateModel.username"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="密码" prop="password">
|
||
<lay-input v-model="validateModel.password" type="password">></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="爱好" prop="hobby">
|
||
<lay-select v-model="validateModel.hobby" multiple>
|
||
<lay-select-option value="1" label="学习"></lay-select-option>
|
||
<lay-select-option value="2" label="编码"></lay-select-option>
|
||
<lay-select-option value="3" label="运动"></lay-select-option>
|
||
</lay-select>
|
||
</lay-form-item>
|
||
<lay-form-item label="特长" prop="specialty">
|
||
<lay-radio v-model="validateModel.specialty" name="specialty" label="1">写作</lay-radio>
|
||
<lay-radio v-model="validateModel.specialty" name="specialty" label="2">画画</lay-radio>
|
||
<lay-radio v-model="validateModel.specialty" name="specialty" label="3">编码</lay-radio>
|
||
</lay-form-item>
|
||
<lay-form-item label="描述" prop="desc">
|
||
<lay-textarea placeholder="请输入描述" v-model="validateModel.desc"></lay-textarea>
|
||
</lay-form-item>
|
||
<lay-form-item>
|
||
<lay-button @click="validate">提交</lay-button>
|
||
<lay-button @click="clearValidate">清除校验</lay-button>
|
||
<lay-button @click="reset">重置表单</lay-button>
|
||
</lay-form-item>
|
||
</lay-form>
|
||
</template>
|
||
|
||
<script>
|
||
import { ref, reactive } from 'vue'
|
||
import {layer} from '@layui/layer-vue'
|
||
|
||
export default {
|
||
setup() {
|
||
|
||
const validateModel = reactive({
|
||
username: "",
|
||
password: "",
|
||
specialty: "1"
|
||
})
|
||
|
||
const layFormRef = ref(null);
|
||
// 校验
|
||
const validate = function() {
|
||
layFormRef.value.validate((isValidate, model, errors) => {
|
||
layer.open({
|
||
type: 1,
|
||
title:"表单提交结果",
|
||
content: `<div style="padding: 10px"><p>是否通过 : ${isValidate}</p> <p>表单数据 : ${JSON.stringify(model)} </p> <p>错误信息 : ${JSON.stringify(errors)}</p></div>`,
|
||
shade: false,
|
||
isHtmlFragment: true,
|
||
btn : [{ text: '确认', callback(index) { layer.close(index) }}],
|
||
area : '500px'
|
||
});
|
||
});
|
||
}
|
||
|
||
// 清除校验
|
||
const clearValidate = function() {
|
||
layFormRef.value.clearValidate();
|
||
}
|
||
|
||
// 重置表单
|
||
const reset = function() {
|
||
layFormRef.value.reset();
|
||
validateModel.specialty = "1"
|
||
}
|
||
|
||
return {
|
||
validateModel,
|
||
layFormRef,
|
||
validate,
|
||
clearValidate,
|
||
reset
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
:::
|
||
|
||
::: title 校验规则 - 通过表单配置
|
||
:::
|
||
|
||
::: demo
|
||
|
||
<template>
|
||
<lay-form :model="ruleDemo1" ref="layFormRef1" :rules="rules" required initValidate>
|
||
<lay-form-item label="邮箱" prop="email">
|
||
<lay-input v-model="ruleDemo1.email"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="url路径" prop="url">
|
||
<lay-input v-model="ruleDemo1.url"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="日期" prop="date">
|
||
<lay-input v-model="ruleDemo1.date"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="用户名" prop="username">
|
||
<lay-input v-model="ruleDemo1.username"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="年龄" prop="age">
|
||
<lay-input v-model="ruleDemo1.age"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item>
|
||
<lay-button @click="validate1">提交</lay-button>
|
||
</lay-form-item>
|
||
</lay-form>
|
||
</template>
|
||
|
||
<script>
|
||
import { ref, reactive } from 'vue'
|
||
import {layer} from '@layui/layer-vue'
|
||
|
||
export default {
|
||
setup() {
|
||
|
||
const ruleDemo1 = reactive({
|
||
email: "",
|
||
url: "",
|
||
date: "",
|
||
username: "",
|
||
age: null,
|
||
})
|
||
|
||
const rules = ref({
|
||
email : {
|
||
type : 'email'
|
||
},
|
||
url : {
|
||
type : 'url'
|
||
},
|
||
date : {
|
||
type : 'date'
|
||
},
|
||
username : {
|
||
type : 'string',
|
||
min : 8,
|
||
max : 16
|
||
},
|
||
age : {
|
||
validator(rule, value, callback, source, options){
|
||
if (value < 18) {
|
||
callback(new Error(`${rule.field}太过于年轻`));
|
||
} else {
|
||
return true;
|
||
}
|
||
}
|
||
}
|
||
})
|
||
|
||
const layFormRef1 = ref(null);
|
||
// 校验
|
||
const validate1 = function() {
|
||
layFormRef1.value.validate((isValidate, model, errors) => {
|
||
layer.open({
|
||
type: 1,
|
||
title:"表单提交结果",
|
||
content: `<div style="padding: 10px"><p>是否通过 : ${isValidate}</p> <p>表单数据 : ${JSON.stringify(model)} </p> <p>错误信息 : ${JSON.stringify(errors)}</p></div>`,
|
||
shade: false,
|
||
isHtmlFragment: true,
|
||
btn : [{ text: '确认', callback(index) { layer.close(index) }}],
|
||
area : '500px'
|
||
});
|
||
});
|
||
}
|
||
|
||
return {
|
||
ruleDemo1,
|
||
layFormRef1,
|
||
validate1,
|
||
rules
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
:::
|
||
|
||
::: title 校验规则 - 通过表单子项配置
|
||
:::
|
||
|
||
::: demo
|
||
|
||
<template>
|
||
<lay-form :model="ruleDemo2" ref="layFormRef2" required initValidate>
|
||
<lay-form-item label="邮箱" prop="email" :rules="{type : 'email'}">
|
||
<lay-input v-model="ruleDemo2.email"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="url路径" prop="url" :rules="{type : 'url'}">
|
||
<lay-input v-model="ruleDemo2.url"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="日期" prop="date" :rules="{type : 'date'}">
|
||
<lay-input v-model="ruleDemo2.date"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="用户名" prop="username"
|
||
:rules="{
|
||
type : 'string',
|
||
min : 8,
|
||
max : 16
|
||
}">
|
||
<lay-input v-model="ruleDemo2.username"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="年龄" prop="age" :rules="ageRules">
|
||
<lay-input v-model="ruleDemo2.age"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="自定义提示" prop="myEmail"
|
||
:rules="{
|
||
type : 'email',
|
||
message : '必须为邮箱'
|
||
}">
|
||
<lay-input v-model="ruleDemo2.myEmail"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item>
|
||
<lay-button @click="validate2">提交</lay-button>
|
||
</lay-form-item>
|
||
</lay-form>
|
||
</template>
|
||
|
||
<script>
|
||
import { ref, reactive } from 'vue'
|
||
import {layer} from '@layui/layer-vue'
|
||
|
||
export default {
|
||
setup() {
|
||
|
||
const ruleDemo2 = reactive({
|
||
email: "",
|
||
url: "",
|
||
date: "",
|
||
username: "",
|
||
age: null,
|
||
myEmail: "",
|
||
});
|
||
|
||
const ageRules = {
|
||
validator(rule, value, callback, source, options){
|
||
if (value < 18) {
|
||
callback(new Error(`${rule.field}太过于年轻`));
|
||
return false;
|
||
}
|
||
return true;
|
||
}
|
||
};
|
||
|
||
const layFormRef2 = ref(null);
|
||
// 校验
|
||
const validate2 = function() {
|
||
layFormRef2.value.validate((isValidate, model, errors) => {
|
||
layer.open({
|
||
type: 1,
|
||
title:"表单提交结果",
|
||
content: `<div style="padding: 10px"><p>是否通过 : ${isValidate}</p> <p>表单数据 : ${JSON.stringify(model)} </p> <p>错误信息 : ${JSON.stringify(errors)}</p></div>`,
|
||
shade: false,
|
||
isHtmlFragment: true,
|
||
btn : [{ text: '确认', callback(index) { layer.close(index) }}],
|
||
area : '500px'
|
||
});
|
||
});
|
||
}
|
||
|
||
return {
|
||
ruleDemo2,
|
||
layFormRef2,
|
||
validate2,
|
||
ageRules
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
:::
|
||
|
||
::: title 原生submit方式校验 -- 校验通过将提交表单 -- 不推荐使用
|
||
:::
|
||
|
||
::: demo
|
||
|
||
<template>
|
||
<lay-form @submit="submit" :model="submitModel" requiredIcons="layui-icon-heart-fill" :use-CN="false" required>
|
||
<lay-form-item label="账户" prop="username">
|
||
<template #label>
|
||
<i class="layui-icon layui-icon-username"></i>
|
||
账户
|
||
</template>
|
||
<lay-input v-model="submitModel.username"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item label="密码" prop="password">
|
||
<lay-input v-model="submitModel.password"></lay-input>
|
||
</lay-form-item>
|
||
<lay-form-item>
|
||
<lay-button native-type="submit">提交</lay-button>
|
||
</lay-form-item>
|
||
</lay-form>
|
||
</template>
|
||
|
||
<script>
|
||
import { ref, reactive } from 'vue'
|
||
import {layer} from '@layui/layer-vue'
|
||
|
||
export default {
|
||
setup() {
|
||
|
||
const submitModel = reactive({
|
||
username: "",
|
||
password: ""
|
||
})
|
||
|
||
const submit = function(isValidate, model, errors) {
|
||
layer.open({
|
||
type: 1,
|
||
title:"表单提交结果",
|
||
content: `<div style="padding: 10px"><p>是否通过 : ${isValidate}</p> <p>表单数据 : ${JSON.stringify(model)} </p> <p>错误信息 : </br>${JSON.stringify(errors)}</p></div>`,
|
||
shade: false,
|
||
isHtmlFragment: true,
|
||
btn : [{ text: '确认', callback(index) { layer.close(index) }}],
|
||
area : '500px'
|
||
})
|
||
}
|
||
|
||
return {
|
||
submitModel
|
||
}
|
||
}
|
||
}
|
||
</script>
|
||
|
||
:::
|
||
|
||
::: title 表单(form)属性
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 类型 | 可选值 | 默认值 |
|
||
| ------------- | -------------------------------------------------------------- | --------- | -------------- | ------- |
|
||
| v-model | 表单绑定值 | `object` | - | {} |
|
||
| required | 是否必填 | `boolean` | `true` `false` | `false` |
|
||
| rules | 表单校验规则; <br>可查看[async-validator](https://github.com/yiminghe/async-validator) | `object` | - | - |
|
||
| initValidate | 是否一开始就校验表单 | `boolean` | `true` `false` | `false` |
|
||
| useCN | 是否使用中文错误提示 | `boolean` | `true` `false` | `false` |
|
||
| requiredIcons | 必填前缀图标`class` | `string` | - | `*` |
|
||
| required-erroer-message | 必填错误提示信息 | `string` | - | `%s不能为空`|
|
||
| validate-message | 自定义校验错误提示信息; <br>由于内置了中文错误提示,可按需求增量增加<br>可查看 [async-validator 内置错误提示](https://github.com/yiminghe/async-validator/blob/master/src/messages.ts)<br>也可参考 [layui-vue 内置中文错误提示](https://gitee.com/layui-vue/layui-vue/tree/develop/src/module/formItem/cnValidateMessage.ts) | `string` | - | `%s不能为空`|
|
||
|
||
:::
|
||
|
||
::: title 表单(form)事件
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 回调参数 |
|
||
| ------------- | ------------------------------- | -------------- |
|
||
| submit | 提交事件`(不推荐使用)` | (`isValidate`, `model`, `errors`)<br><br> `isValidate`: (`boolean`)是否校验通过<br><br> `model`: (`object`)表单绑定的值<br><br> `errors`: (`Array`)校验结果的错误信息 |
|
||
|
||
|
||
:::
|
||
|
||
::: title 表单(form)方法
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 入参 |
|
||
| ------------- | -------------- | -------------- |
|
||
| validate | 表单校验; <br>如果没有`callback`回调,会返回`Promise`, <br> `Promise`参数为{`isValidate`, `model`, `errors`}<br> 参数具体描述请看上面表单`submit`提交事件 | (`fields` `[可选]`, `callback` `[可选]`)<br><br> `fields`: (`string` / `string[]` / `function`)<br>单独校验的字段,<br>该字段如果为`function`, <br>则认为`callback`入参,校验全部字段;<br><br> `callback`: (`function`)校验之后的回调,<br>回调参数为(`isValidate`, `model`, `errors`);<br>参数具体描述请看上面表单`submit`提交事件|
|
||
| clearValidate | 清除表单校验 | (`fields`[可选])<br><br> `fields`: (`string` / `string[]`)<br>需要进行清除校验的表单字段, 如果该字段为空则清除全部校验|
|
||
| reset | 重置表单所有值 | - |
|
||
|
||
|
||
:::
|
||
|
||
::: title 表单项(form-item)属性
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 类型 | 可选值 | 默认值 |
|
||
| ------------- | -------------------------------------------------------------- | --------- | -------------- | ------- |
|
||
| prop | 在表单绑定值(`model`)中字段`key` | `string` | - | - |
|
||
| label | 子项前边描述值,**尽量填写**,中文校验错误需要用到 | `string` | - | - |
|
||
| required | 是否必填 | `boolean` | `true` `false` | `false` |
|
||
| rules | 表单校验规则; <br>可查看[async-validator](https://github.com/yiminghe/async-validator) | `object` | - | - |
|
||
| error-message | 表单校验失败固定提示语 | `string` |`block` `inline`| `block` |
|
||
| mode | 表单项显示的模式,`块元素` / `行元素` | `string` |`block` `inline`| `block` |
|
||
|
||
:::
|
||
|
||
::: title 表单项(form-item)方法
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 入参 |
|
||
| ------------- | -------------- | -------------- |
|
||
| validate | 表单校验; | (`callback` `[可选]`)<br><br> `callback`: (`function`)校验之后的回调,<br>回调参数为(`errors`, `fields`);<br><br> `errors`: (`Array`)校验结果的错误信息;<br><br> `fields`: (`Array`)当前校验的字段信息|
|
||
| clearValidate | 清除表单校验 | - |
|
||
|
||
|
||
:::
|
||
|
||
::: title 表单项(form-item)插槽
|
||
:::
|
||
|
||
::: table
|
||
|
||
| 属性 | 描述 | 可使用参数 |
|
||
| ------------- | ---------------------------------------------------------------- | --------------------------------------- |
|
||
| - | 默认插槽 | 传递进来的`props`和表单绑定的值(`model`) |
|
||
| label | 子项前边描述插槽<br>如果使用此插槽,`props`**尽量**也传递`label`参数 | 传递进来的`props`和表单绑定的值(`model`) |
|
||
| required | 必填前缀插槽 | `*` / `表单props` 中的 `requiredIcons` |
|
||
|
||
:::
|
||
|
||
::: title 关于 async-validator 的使用
|
||
:::
|
||
|
||
查看: https://github.com/yiminghe/async-validator
|
||
中文翻译: https://www.cnblogs.com/wozho/p/10955525.html
|
||
|
||
::: title async-validator 基本校验类型
|
||
:::
|
||
|
||
::: table
|
||
| 属性 | 描述 | 使用方式 |
|
||
| -------------| ----------------- | ------------------- |
|
||
| number | 数字 | `{type : 'number'}` |
|
||
| boolean | 布尔类型 | `{type : 'boolean'}` |
|
||
| method | 方法 | `{type : 'method'}` |
|
||
| regexp | 正则表达式 | `{type : 'regexp'}` |
|
||
| integer | 整型数字 | `{type : 'integer'}` |
|
||
| float | 浮点小数 | `{type : 'float'}` |
|
||
| array | 数组 | `{type : 'array'}` |
|
||
| object | 对象 | `{type : 'object'}` |
|
||
| enum | 枚举 | `{type : 'enum'}` |
|
||
| date | 日期 | `{type : 'date'}` |
|
||
| url | url | `{type : 'url'}` |
|
||
| hex | 十六进制 | `{type : 'hex'}` |
|
||
| email | 邮箱 | `{type : 'email'}` |
|
||
:::
|
||
|
||
::: title async-validator 中 validator参数使用
|
||
:::
|
||
|
||
```javascript
|
||
{
|
||
validator: (rule, value) => value === 'root'
|
||
}
|
||
```
|
||
|
||
::: title async-validator 中 asyncValidator参数使用
|
||
:::
|
||
|
||
```javascript
|
||
{
|
||
asyncValidator: (rule, value) => {
|
||
return new Promise((resolve, reject) => {
|
||
if (value < 18) {
|
||
reject('too young'); // reject with error message
|
||
} else {
|
||
resolve();
|
||
}
|
||
});
|
||
}
|
||
}
|
||
```
|
||
|
||
|
||
::: title form 配置 async-validator 的使用
|
||
:::
|
||
|
||
```javascript
|
||
{
|
||
key : rule // key为表单子项需要校验的对应key名称, rule为校验规则,格式为{}
|
||
}
|
||
// 例如 表单绑定值为 {email : 'xxx', username: 'xxxxx'}
|
||
// 需要校验邮箱,而邮箱输入框在表单绑定的值中key为email,
|
||
// 需要校验用户名长度为8到16之间,而用户名输入框在表单绑定的值中key为username,
|
||
{
|
||
email : {
|
||
type : 'email'
|
||
},
|
||
username : {
|
||
type : 'string',
|
||
min : 8,
|
||
max : 16
|
||
}
|
||
}
|
||
```
|
||
|
||
::: title form-item 配置 async-validator 的使用
|
||
:::
|
||
|
||
```javascript
|
||
// 例如 表单绑定值为 {email : 'xxx', phone: 'xxxxx'}
|
||
// 需要校验邮箱,而邮箱输入框在表单绑定的值中key为email
|
||
{
|
||
type : 'email'
|
||
}
|
||
```
|
||
|
||
|
||
|
||
|
||
::: previousNext form
|
||
::: |