参数校验相关提交

master
Chopper 2021-09-22 12:16:22 +08:00
parent c33d10734f
commit 2932c7f35d
3 changed files with 55 additions and 13 deletions

View File

@ -57,3 +57,24 @@ export const URL =
// 固话 // 固话
export const TEL = /0\d{2,3}-\d{7,8}/ export const TEL = /0\d{2,3}-\d{7,8}/
// 正整数
export const INTEGER = {
pattern: /^[0-9]\d*$/,
message:'请输入正整数'
}
export const VARCHAR20 = {
pattern:/^.{3,20}$/,
message:'长度应该限制在3-20个字符'
}
export const URL200 = {
pattern:/[a-zA-z]+\:\/\/[^\s]{1,190}/,
message:'请输入长度不超过200的URL地址'
}
export const REQUIRED = {
required: true,
message:'请填写参数'
}

View File

@ -1,9 +1,10 @@
<template> <template>
<div class="search"> <div class="search">
<Card> <Card>
<Form ref="searchForm" @keydown.enter.native="handleSearch" :model="searchForm" inline :label-width="70" class="search-form"> <Form ref="searchForm" @keydown.enter.native="handleSearch" :model="searchForm" inline :label-width="70"
class="search-form">
<Form-item label="品牌名称"> <Form-item label="品牌名称">
<Input type="text" v-model="searchForm.name" placeholder="请输入品牌名称" clearable style="width: 200px" /> <Input type="text" v-model="searchForm.name" placeholder="请输入品牌名称" clearable style="width: 200px"/>
</Form-item> </Form-item>
<Button @click="handleSearch" type="primary">搜索</Button> <Button @click="handleSearch" type="primary">搜索</Button>
</Form> </Form>
@ -12,14 +13,15 @@
</Row> </Row>
<Table :loading="loading" border :columns="columns" :data="data" ref="table"></Table> <Table :loading="loading" border :columns="columns" :data="data" ref="table"></Table>
<Row type="flex" justify="end" class="mt_10"> <Row type="flex" justify="end" class="mt_10">
<Page :current="searchForm.pageNumber" :total="total" :page-size="searchForm.pageSize" @on-change="changePage" @on-page-size-change="changePageSize" :page-size-opts="[10, 20, 50]" size="small" <Page :current="searchForm.pageNumber" :total="total" :page-size="searchForm.pageSize" @on-change="changePage"
show-total show-elevator show-sizer></Page> @on-page-size-change="changePageSize" :page-size-opts="[10, 20, 50]" size="small"
show-total show-elevator show-sizer></Page>
</Row> </Row>
</Card> </Card>
<Modal :title="modalTitle" v-model="modalVisible" :mask-closable="false" :width="500"> <Modal :title="modalTitle" v-model="modalVisible" :mask-closable="false" :width="500">
<Form ref="form" :model="form" :label-width="100" :rules="formValidate"> <Form ref="form" :model="form" :label-width="100" :rules="formValidate">
<FormItem label="品牌名称" prop="name"> <FormItem label="品牌名称" prop="name">
<Input v-model="form.name" clearable style="width: 100%" /> <Input v-model="form.name" clearable style="width: 100%"/>
</FormItem> </FormItem>
<FormItem label="品牌图标" prop="logo"> <FormItem label="品牌图标" prop="logo">
<upload-pic-input v-model="form.logo" style="width: 100%"></upload-pic-input> <upload-pic-input v-model="form.logo" style="width: 100%"></upload-pic-input>
@ -43,6 +45,8 @@ import {
} from "@/api/goods"; } from "@/api/goods";
import uploadPicInput from "@/views/my-components/lili/upload-pic-input"; import uploadPicInput from "@/views/my-components/lili/upload-pic-input";
import {regular} from "@/utils";
export default { export default {
name: "brand", name: "brand",
components: { components: {
@ -68,7 +72,16 @@ export default {
deleteFlag: "", deleteFlag: "",
}, },
// //
formValidate: {}, formValidate: {
name: [
regular.REQUIRED,
regular.VARCHAR20
],
logo: [
regular.REQUIRED,
regular.URL200
],
},
submitLoading: false, // submitLoading: false, //
columns: [ columns: [
{ {
@ -104,9 +117,9 @@ export default {
align: "left", align: "left",
render: (h, params) => { render: (h, params) => {
if (params.row.deleteFlag == 0) { if (params.row.deleteFlag == 0) {
return h("Tag", {props: {color: "green",},},"启用"); return h("Tag", {props: {color: "green",},}, "启用");
} else if (params.row.deleteFlag == 1) { } else if (params.row.deleteFlag == 1) {
return h("Tag", {props: {color: "volcano",},},"禁用"); return h("Tag", {props: {color: "volcano",},}, "禁用");
} }
}, },
filters: [ filters: [
@ -323,7 +336,7 @@ export default {
content: "您确认要启用品牌 " + v.name + " ?", content: "您确认要启用品牌 " + v.name + " ?",
loading: true, loading: true,
onOk: () => { onOk: () => {
disableBrand(v.id, { disable: false }).then((res) => { disableBrand(v.id, {disable: false}).then((res) => {
this.$Modal.remove(); this.$Modal.remove();
if (res.success) { if (res.success) {
this.$Message.success("操作成功"); this.$Message.success("操作成功");
@ -340,7 +353,7 @@ export default {
content: "您确认要禁用品牌 " + v.name + " ?", content: "您确认要禁用品牌 " + v.name + " ?",
loading: true, loading: true,
onOk: () => { onOk: () => {
disableBrand(v.id, { disable: true }).then((res) => { disableBrand(v.id, {disable: true}).then((res) => {
this.$Modal.remove(); this.$Modal.remove();
if (res.success) { if (res.success) {
this.$Message.success("操作成功"); this.$Message.success("操作成功");

View File

@ -171,9 +171,17 @@ export default {
// //
formValidate: { formValidate: {
commissionRate: [ commissionRate: [
{ required: true, message: "请填写佣金比例" }, regular.REQUIRED,
{ pattern: regular.Integer, message: "佣金比例不能为负" }, regular.INTEGER
], ],
name:[
regular.REQUIRED,
regular.VARCHAR20,
],
sortOrder:[
regular.REQUIRED,
regular.INTEGER
]
}, },
columns: [ columns: [
{ {
@ -475,4 +483,4 @@ export default {
min-height: 100vh; min-height: 100vh;
height: auto; height: auto;
} }
</style> </style>