mirror of
https://gitee.com/element-plus/element-plus.git
synced 2024-12-05 04:37:47 +08:00
7173e402b7
* feat(components): [form-item] auto attach labels to inputs * feat(components): [form-item] auto-attach up through select * feat(components): [form-item] auto id complete for all inputs * feat(components): [form-item] fix lint, remove unused usePopper hook * feat(components): [form-item] PR comments
100 lines
2.7 KiB
Vue
100 lines
2.7 KiB
Vue
<template>
|
|
<div>
|
|
<el-radio-group v-model="size" label="size control">
|
|
<el-radio-button label="large">large</el-radio-button>
|
|
<el-radio-button label="default">default</el-radio-button>
|
|
<el-radio-button label="small">small</el-radio-button>
|
|
</el-radio-group>
|
|
<el-radio-group v-model="labelPosition" label="position control">
|
|
<el-radio-button label="left">Left</el-radio-button>
|
|
<el-radio-button label="right">Right</el-radio-button>
|
|
<el-radio-button label="top">Top</el-radio-button>
|
|
</el-radio-group>
|
|
</div>
|
|
<br />
|
|
<el-form
|
|
ref="form"
|
|
:model="sizeForm"
|
|
label-width="auto"
|
|
:label-position="labelPosition"
|
|
:size="size"
|
|
>
|
|
<el-form-item label="Activity name">
|
|
<el-input v-model="sizeForm.name" />
|
|
</el-form-item>
|
|
<el-form-item label="Activity zone">
|
|
<el-select
|
|
v-model="sizeForm.region"
|
|
placeholder="please select your zone"
|
|
>
|
|
<el-option label="Zone one" value="shanghai" />
|
|
<el-option label="Zone two" value="beijing" />
|
|
</el-select>
|
|
</el-form-item>
|
|
<el-form-item label="Activity time">
|
|
<el-col :span="11">
|
|
<el-date-picker
|
|
v-model="sizeForm.date1"
|
|
type="date"
|
|
label="Pick a date"
|
|
placeholder="Pick a date"
|
|
style="width: 100%"
|
|
/>
|
|
</el-col>
|
|
<el-col class="text-center" :span="1" style="margin: 0 0.5rem">-</el-col>
|
|
<el-col :span="11">
|
|
<el-time-picker
|
|
v-model="sizeForm.date2"
|
|
label="Pick a time"
|
|
placeholder="Pick a time"
|
|
style="width: 100%"
|
|
/>
|
|
</el-col>
|
|
</el-form-item>
|
|
<el-form-item label="Activity type">
|
|
<el-checkbox-group v-model="sizeForm.type">
|
|
<el-checkbox-button label="Online activities" name="type" />
|
|
<el-checkbox-button label="Promotion activities" name="type" />
|
|
</el-checkbox-group>
|
|
</el-form-item>
|
|
<el-form-item label="Resources">
|
|
<el-radio-group v-model="sizeForm.resource">
|
|
<el-radio border label="Sponsor" />
|
|
<el-radio border label="Venue" />
|
|
</el-radio-group>
|
|
</el-form-item>
|
|
<el-form-item>
|
|
<el-button type="primary" @click="onSubmit">Create</el-button>
|
|
<el-button>Cancel</el-button>
|
|
</el-form-item>
|
|
</el-form>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { reactive, ref } from 'vue'
|
|
|
|
const size = ref('default')
|
|
const labelPosition = ref('right')
|
|
|
|
const sizeForm = reactive({
|
|
name: '',
|
|
region: '',
|
|
date1: '',
|
|
date2: '',
|
|
delivery: false,
|
|
type: [],
|
|
resource: '',
|
|
desc: '',
|
|
})
|
|
|
|
function onSubmit() {
|
|
console.log('submit!')
|
|
}
|
|
</script>
|
|
|
|
<style>
|
|
.el-radio-group {
|
|
margin-right: 12px;
|
|
}
|
|
</style>
|