layout.vue
<template>
<div>
<el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="100px">
<el-row gutter="15">
</el-row>
<el-form-item size="large">
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button @click="resetForm">重置</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
components: {},
props: [],
data() {
return {
formData: {},
rules: {},
}
},
computed: {},
watch: {},
created() {},
mounted() {},
methods: {
submitForm() {
this.$refs['elForm'].validate(valid => {
if (!valid) return
})
},
resetForm() {
this.$refs['elForm'].resetFields()
},
}
}
</script>
<style>
</style>
select.vue
<template>
<div>
<el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="100px">
<el-form-item label="下拉选择" prop="field116">
<el-select v-model="formData.field116" placeholder="请选择下拉选择" clearable :style="{width: '100%'}">
<el-option v-for="(item, index) in field116Options" :key="index" :label="item.label"
:value="item.value" :disabled="item.disabled"></el-option>
</el-select>
</el-form-item>
<el-form-item label="级联选择" prop="field117">
<el-cascader v-model="formData.field117" :options="field117Options" :props="field117Props"
:style="{width: '100%'}" placeholder="请选择级联选择" clearable></el-cascader>
</el-form-item>
<el-form-item label="单选框组" prop="field118">
<el-radio-group v-model="formData.field118" size="medium">
<el-radio v-for="(item, index) in field118Options" :key="index" :label="item.value"
:disabled="item.disabled">{{item.label}}</el-radio>
</el-radio-group>
</el-form-item>
<el-form-item label="多选框组" prop="field119">
<el-checkbox-group v-model="formData.field119" size="medium">
<el-checkbox v-for="(item, index) in field119Options" :key="index" :label="item.value"
:disabled="item.disabled">{{item.label}}</el-checkbox>
</el-checkbox-group>
</el-form-item>
<el-form-item label="上传" prop="field124" required>
<el-upload ref="field124" :file-list="field124fileList" :action="field124Action"
:before-upload="field124BeforeUpload">
<el-button size="small" type="primary" icon="el-icon-upload">点击上传</el-button>
</el-upload>
</el-form-item>
<el-form-item size="large">
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button @click="resetForm">重置</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
components: {},
props: [],
data() {
return {
formData: {
field116: undefined,
field117: [1, 2],
field118: undefined,
field119: [],
field124: null,
},
rules: {
field116: [{
required: true,
message: '请选择下拉选择',
trigger: 'change'
}],
field117: [{
required: true,
type: 'array',
message: '请至少选择一个field117',
trigger: 'change'
}],
field118: [{
required: true,
message: '单选框组不能为空',
trigger: 'change'
}],
field119: [{
required: true,
type: 'array',
message: '请至少选择一个field119',
trigger: 'change'
}],
},
field124Action: 'https://jsonplaceholder.typicode.com/posts/',
field124fileList: [],
field116Options: [{
"label": "选项一",
"value": 1
}, {
"label": "选项二",
"value": 2
}],
field117Options: [],
field118Options: [{
"label": "选项一",
"value": 1
}, {
"label": "选项二",
"value": 2
}],
field119Options: [{
"label": "选项一",
"value": 1
}, {
"label": "选项二",
"value": 2
}],
field117Props: {
"multiple": false
},
}
},
computed: {},
watch: {},
created() {},
mounted() {},
methods: {
submitForm() {
this.$refs['elForm'].validate(valid => {
if (!valid) return
})
},
resetForm() {
this.$refs['elForm'].resetFields()
},
getField117Options() {
this.field117Options
},
field124BeforeUpload(file) {
let isRightSize = file.size / 1024 / 1024 < 2
if (!isRightSize) {
this.$message.error('文件大小超过 2MB')
}
return isRightSize
},
}
}
</script>
<style>
.el-upload__tip {
line-height: 1.2;
}
</style>
form.vue
<template>
<div>
<el-form ref="elForm" :model="formData" :rules="rules" size="medium" label-width="100px">
<el-form-item label="单行文本" prop="field110">
<el-input v-model="formData.field110" placeholder="请输入单行文本" clearable :style="{width: '100%'}">
</el-input>
</el-form-item>
<el-form-item label="下拉选择" prop="field111">
<el-select v-model="formData.field111" placeholder="请选择下拉选择" clearable :style="{width: '100%'}">
<el-option v-for="(item, index) in field111Options" :key="index" :label="item.label"
:value="item.value" :disabled="item.disabled"></el-option>
</el-select>
</el-form-item>
<el-form-item label="时间选择" prop="field112">
<el-time-picker v-model="formData.field112" format="HH:mm:ss" value-format="HH:mm:ss"
:picker-options='{"selectableRange":"00:00:00-23:59:59"}' :style="{width: '100%'}"
placeholder="请选择时间选择" clearable></el-time-picker>
</el-form-item>
<el-form-item label="时间范围" prop="field113">
<el-time-picker v-model="formData.field113" is-range format="HH:mm:ss" value-format="HH:mm:ss"
:style="{width: '100%'}" start-placeholder="开始时间" end-placeholder="结束时间" range-separator="至"
clearable></el-time-picker>
</el-form-item>
<el-form-item label="日期选择" prop="field114">
<el-date-picker v-model="formData.field114" format="yyyy-MM-dd" value-format="yyyy-MM-dd"
:style="{width: '100%'}" placeholder="请选择日期选择" clearable></el-date-picker>
</el-form-item>
<el-form-item label="日期范围" prop="field115">
<el-date-picker type="daterange" v-model="formData.field115" format="yyyy-MM-dd"
value-format="yyyy-MM-dd" :style="{width: '100%'}" start-placeholder="开始日期" end-placeholder="结束日期"
range-separator="至" clearable></el-date-picker>
</el-form-item>
<el-form-item size="large">
<el-button type="primary" @click="submitForm">提交</el-button>
<el-button @click="resetForm">重置</el-button>
</el-form-item>
</el-form>
</div>
</template>
<script>
export default {
components: {},
props: [],
data() {
return {
formData: {
field110: undefined,
field111: undefined,
field112: null,
field113: null,
field114: null,
field115: null,
},
rules: {
field110: [{
required: true,
message: '请输入单行文本',
trigger: 'blur'
}],
field111: [{
required: true,
message: '请选择下拉选择',
trigger: 'change'
}],
field112: [{
required: true,
message: '请选择时间选择',
trigger: 'change'
}],
field113: [{
required: true,
message: '时间范围不能为空',
trigger: 'change'
}],
field114: [{
required: true,
message: '请选择日期选择',
trigger: 'change'
}],
field115: [{
required: true,
message: '日期范围不能为空',
trigger: 'change'
}],
},
field111Options: [{
"label": "选项一",
"value": 1
}, {
"label": "选项二",
"value": 2
}],
}
},
computed: {},
watch: {},
created() {},
mounted() {},
methods: {
submitForm() {
this.$refs['elForm'].validate(valid => {
if (!valid) return
})
},
resetForm() {
this.$refs['elForm'].resetFields()
},
}
}
</script>
<style>
</style>