iview/examples/routers/select.vue

214 lines
9.2 KiB
Vue
Raw Normal View History

<template>
2019-10-08 11:46:18 +08:00
<div>
{{formValidate}}
<Form ref="formValidate" :model="formValidate" :rules="ruleValidate" :label-width="80">
<FormItem label="Hobby" prop="ainterest">
<Select
multiple
:max-tag-count="1"
v-model="formValidate.ainterest"
>
<Option value="Eat">Eat</Option>
<Option value="Sleep">Sleep</Option>
<Option value="Run">Run</Option>
<Option value="Movie">Movie</Option>
</Select>
</FormItem>
<FormItem label="Hobby" prop="binterest">
<CheckboxGroup v-model="formValidate.binterest">
<Checkbox label="Eat"></Checkbox>
<Checkbox label="Sleep"></Checkbox>
<Checkbox label="Run"></Checkbox>
<Checkbox label="Movie"></Checkbox>
</CheckboxGroup>
</FormItem>
<FormItem>
<Button type="primary" @click="handleSubmit('formValidate')">Submit</Button>
<Button @click="handleReset('formValidate')" style="margin-left: 8px">Reset</Button>
</FormItem>
</Form>
2019-11-22 15:07:09 +08:00
<h2 style="margin-top:20px">#5327 feature</h2>
2019-11-07 12:19:23 +08:00
<Select v-model='test' filterable clearable>
2019-11-12 18:41:28 +08:00
<Option v-for='item in list' :value='item.value' :label="item.name" :key="item.value"></Option>
2019-11-22 15:07:09 +08:00
<div slot="empty">2222</div>
2019-11-12 18:41:28 +08:00
</Select>
<h2 style="margin-top:20px">#5216</h2>
<Select v-model="model11" filterable clearable>
<OptionGroup label="分组">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</OptionGroup>
</Select>
<h2 style="margin-top:20px">Demo</h2>
<Select v-model="model12">
<OptionGroup label="分组">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</OptionGroup>
2019-11-07 12:19:23 +08:00
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<br><br>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select v-model="model1" style="width:200px">
<Icon type="ios-alarm" slot="prefix" color="red" />
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select v-model="model1" style="width:200px">
<Avatar src="https://dev-file.iviewui.com/userinfoPDvn9gKWYihR24SpgC319vXY8qniCqj4/avatar" slot="prefix" size="small" />
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select v-model="model10" :max-tag-count="3" :max-tag-placeholder="more" multiple style="width:400px" prefix="ios-albums">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<br><br>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select size="small" v-model="model1" style="width:200px" prefix="ios-albums">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select size="small" v-model="model10" multiple style="width:400px" prefix="ios-albums">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<br><br>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select size="large" v-model="model1" style="width:200px" prefix="ios-albums">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
2019-09-11 14:27:19 +08:00
<Select size="large" v-model="model10" multiple style="width:400px" prefix="ios-albums">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-09-09 13:45:01 +08:00
<Divider></Divider>
<Select v-model="model13" filterable allow-create @on-create="handleCreate" style="width:260px">
2019-08-27 09:42:40 +08:00
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-09-09 14:41:42 +08:00
<Select v-model="model12" multiple filterable allow-create @on-create="handleCreate" style="width:260px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-09-14 17:49:56 +08:00
<Divider></Divider>
<Select v-model="model31" size="small" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model31" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model31" size="large" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Divider></Divider>
2019-09-14 18:12:52 +08:00
<Select v-model="model31" filterable size="small" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model31" filterable style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model31" filterable size="large" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Divider></Divider>
2019-09-14 17:49:56 +08:00
<Select v-model="model34" multiple size="small" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model34" multiple style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model34" multiple size="large" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-09-14 18:12:52 +08:00
<Divider></Divider>
<Select v-model="model34" filterable multiple size="small" style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
<Select v-model="model34" filterable multiple style="width:200px">
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-09-14 18:26:37 +08:00
<Select v-model="model34" filterable allow-create multiple size="large" style="width:200px">
2019-09-14 18:12:52 +08:00
<Option v-for="item in cityList" :value="item.value" :key="item.value">{{ item.label }}</Option>
</Select>
2019-08-27 09:42:40 +08:00
</div>
</template>
<script>
2018-06-28 11:48:30 +08:00
export default {
data () {
return {
2019-10-08 11:46:18 +08:00
formValidate: {
ainterest: [],
binterest: [],
},
ruleValidate: {
ainterest: [
{ required: true, type: 'array', min: 1, message: 'Choose at least one hobby', trigger: 'change' },
],
binterest: [
{ required: true, type: 'array', min: 1, message: 'Choose at least one hobby', trigger: 'change' },
],
2019-11-07 12:19:23 +08:00
},
test:'',
list:[{
2019-11-12 18:41:28 +08:00
name: '测试测试2',
value:1
},{
2019-11-12 18:41:28 +08:00
name: 'dddddd',
value:2
},{
2019-11-12 18:41:28 +08:00
name:'测试测试',
2019-11-07 12:19:23 +08:00
value:8
},{
2019-11-12 18:41:28 +08:00
name: '\"年龄\"123',
2019-11-07 12:19:23 +08:00
value:9
2019-11-12 18:41:28 +08:00
}],
cityList: [
{
value: 'New York',
label: 'New York'
},
{
value: 'London',
label: 'London'
},
{
value: 'Sydney',
label: 'Sydney'
},
{
value: 'Ottawa',
label: 'Ottawa'
},
{
value: 'Paris',
label: 'Paris'
},
{
value: 'Canberra',
label: 'Canberra'
}
],
2019-08-27 09:42:40 +08:00
model1: '',
2019-09-09 13:45:01 +08:00
model10: [],
model12: [],
2019-09-14 17:49:56 +08:00
model13: '',
model31: '',
model32: '',
model33: '',
model34: [],
model35: [],
model36: []
2019-08-27 09:42:40 +08:00
}
},
methods: {
2019-08-27 09:42:40 +08:00
more (num) {
return 'more' + num;
2019-10-08 11:46:18 +08:00
},
2019-09-09 13:45:01 +08:00
handleCreate (val) {
console.log(111,val);
this.cityList.push({
value: val,
label: val
});
}
2018-06-28 11:48:30 +08:00
}
2019-11-12 18:41:28 +08:00
};
2017-09-14 15:49:37 +08:00
</script>