Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
B
basic-vue-admin
概览
概览
详情
活动
周期分析
版本库
存储库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
Basic
basic-vue-admin
Commits
8b4b767f
提交
8b4b767f
authored
7月 21, 2021
作者:
无木
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat(demo): add `async-validator` demo
添加表单使用后端接口异步验证的例子
上级
341bd633
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
66 行增加
和
5 行删除
+66
-5
system.ts
mock/demo/system.ts
+14
-1
system.ts
src/api/demo/system.ts
+4
-0
RuleForm.vue
src/views/demo/form/RuleForm.vue
+30
-3
account.data.ts
src/views/demo/system/account/account.data.ts
+18
-1
没有找到文件。
mock/demo/system.ts
浏览文件 @
8b4b767f
import
{
MockMethod
}
from
'vite-plugin-mock'
;
import
{
MockMethod
}
from
'vite-plugin-mock'
;
import
{
resultPageSuccess
,
resultSuccess
}
from
'../_util'
;
import
{
result
Error
,
result
PageSuccess
,
resultSuccess
}
from
'../_util'
;
const
accountList
=
(()
=>
{
const
accountList
=
(()
=>
{
const
result
:
any
[]
=
[];
const
result
:
any
[]
=
[];
...
@@ -185,4 +185,17 @@ export default [
...
@@ -185,4 +185,17 @@ export default [
return
resultSuccess
(
menuList
);
return
resultSuccess
(
menuList
);
},
},
},
},
{
url
:
'/basic-api/system/accountExist'
,
timeout
:
500
,
method
:
'post'
,
response
:
({
body
})
=>
{
const
{
account
}
=
body
||
{};
if
(
account
&&
account
.
indexOf
(
'admin'
)
!==
-
1
)
{
return
resultError
(
'该字段不能包含admin'
);
}
else
{
return
resultSuccess
(
`
${
account
}
can use`
);
}
},
},
]
as
MockMethod
[];
]
as
MockMethod
[];
src/api/demo/system.ts
浏览文件 @
8b4b767f
...
@@ -14,6 +14,7 @@ import { defHttp } from '/@/utils/http/axios';
...
@@ -14,6 +14,7 @@ import { defHttp } from '/@/utils/http/axios';
enum
Api
{
enum
Api
{
AccountList
=
'/system/getAccountList'
,
AccountList
=
'/system/getAccountList'
,
IsAccountExist
=
'/system/accountExist'
,
DeptList
=
'/system/getDeptList'
,
DeptList
=
'/system/getDeptList'
,
setRoleStatus
=
'/system/setRoleStatus'
,
setRoleStatus
=
'/system/setRoleStatus'
,
MenuList
=
'/system/getMenuList'
,
MenuList
=
'/system/getMenuList'
,
...
@@ -38,3 +39,6 @@ export const getAllRoleList = (params?: RoleParams) =>
...
@@ -38,3 +39,6 @@ export const getAllRoleList = (params?: RoleParams) =>
export
const
setRoleStatus
=
(
id
:
number
,
status
:
string
)
=>
export
const
setRoleStatus
=
(
id
:
number
,
status
:
string
)
=>
defHttp
.
post
({
url
:
Api
.
setRoleStatus
,
params
:
{
id
,
status
}
});
defHttp
.
post
({
url
:
Api
.
setRoleStatus
,
params
:
{
id
,
status
}
});
export
const
isAccountExist
=
(
account
:
string
)
=>
defHttp
.
post
({
url
:
Api
.
IsAccountExist
,
params
:
{
account
}
},
{
errorMessageMode
:
'none'
});
src/views/demo/form/RuleForm.vue
浏览文件 @
8b4b767f
...
@@ -15,9 +15,10 @@
...
@@ -15,9 +15,10 @@
<
script
lang=
"ts"
>
<
script
lang=
"ts"
>
import
{
defineComponent
}
from
'vue'
;
import
{
defineComponent
}
from
'vue'
;
import
{
BasicForm
,
FormSchema
,
useForm
}
from
'/@/components/Form/index'
;
import
{
BasicForm
,
FormSchema
,
useForm
}
from
'/@/components/Form/index'
;
import
{
CollapseContainer
}
from
'/@/components/Container
/index
'
;
import
{
CollapseContainer
}
from
'/@/components/Container'
;
import
{
useMessage
}
from
'/@/hooks/web/useMessage'
;
import
{
useMessage
}
from
'/@/hooks/web/useMessage'
;
import
{
PageWrapper
}
from
'/@/components/Page'
;
import
{
PageWrapper
}
from
'/@/components/Page'
;
import
{
isAccountExist
}
from
'/@/api/demo/system'
;
const
schemas
:
FormSchema
[]
=
[
const
schemas
:
FormSchema
[]
=
[
{
{
...
@@ -120,11 +121,11 @@
...
@@ -120,11 +121,11 @@
validator
:
async
(
rule
,
value
)
=>
{
validator
:
async
(
rule
,
value
)
=>
{
if
(
!
value
)
{
if
(
!
value
)
{
/* eslint-disable-next-line */
/* eslint-disable-next-line */
return
Promise
.
reject
(
'
值不能为空'
);
return
Promise
.
reject
(
'值不能为空'
);
}
}
if
(
value
===
'1'
)
{
if
(
value
===
'1'
)
{
/* eslint-disable-next-line */
/* eslint-disable-next-line */
return
Promise
.
reject
(
'
值不能为1'
);
return
Promise
.
reject
(
'值不能为1'
);
}
}
return
Promise
.
resolve
();
return
Promise
.
resolve
();
},
},
...
@@ -174,6 +175,32 @@
...
@@ -174,6 +175,32 @@
},
},
rules
:
[{
required
:
true
,
message
:
'覆盖默认生成的校验信息'
}],
rules
:
[{
required
:
true
,
message
:
'覆盖默认生成的校验信息'
}],
},
},
{
field
:
'field8'
,
component
:
'Input'
,
label
:
'后端异步验证'
,
colProps
:
{
span
:
8
,
},
helpMessage
:
[
'本字段演示异步验证'
,
'本地规则:必须填写'
,
'后端规则:不能包含admin'
],
rules
:
[
{
required
:
true
,
message
:
'请输入数据'
,
},
{
validator
(
_
,
value
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
isAccountExist
(
value
)
.
then
(()
=>
resolve
())
.
catch
((
err
)
=>
{
reject
(
err
.
message
||
'验证失败'
);
});
});
},
},
],
},
];
];
export
default
defineComponent
({
export
default
defineComponent
({
...
...
src/views/demo/system/account/account.data.ts
浏览文件 @
8b4b767f
import
{
getAllRoleList
}
from
'/@/api/demo/system'
;
import
{
getAllRoleList
,
isAccountExist
}
from
'/@/api/demo/system'
;
import
{
BasicColumn
}
from
'/@/components/Table'
;
import
{
BasicColumn
}
from
'/@/components/Table'
;
import
{
FormSchema
}
from
'/@/components/Table'
;
import
{
FormSchema
}
from
'/@/components/Table'
;
...
@@ -54,7 +54,24 @@ export const accountFormSchema: FormSchema[] = [
...
@@ -54,7 +54,24 @@ export const accountFormSchema: FormSchema[] = [
field
:
'account'
,
field
:
'account'
,
label
:
'用户名'
,
label
:
'用户名'
,
component
:
'Input'
,
component
:
'Input'
,
helpMessage
:
[
'本字段演示异步验证'
,
'不能输入带有admin的用户名'
],
rules
:
[
{
required
:
true
,
required
:
true
,
message
:
'请输入用户名'
,
},
{
validator
(
_
,
value
)
{
return
new
Promise
((
resolve
,
reject
)
=>
{
isAccountExist
(
value
)
.
then
(()
=>
resolve
())
.
catch
((
err
)
=>
{
reject
(
err
.
message
||
'验证失败'
);
});
});
},
},
],
},
},
{
{
field
:
'pwd'
,
field
:
'pwd'
,
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论