Cascader
Install
import Vue from 'vue';
import { Cascader } from 'vant';
Vue.use(Cascader);
Usage
Basic Usage
<van-field
is-link
readonly
label="Area"
:value="fieldValue"
placeholder="Select Area"
@click="show = true"
/>
<van-popup v-model="show" round position="bottom">
<van-cascader
v-model="cascaderValue"
title="Select Area"
@close="show = false"
@finish="onFinish"
/>
</van-popup>
export default {
data() {
return {
show: false,
fieldValue: '',
cascaderValue: '',
options: [
{
text: 'Zhejiang',
value: '330000',
children: [{ text: 'Hangzhou', value: '330100' }],
},
{
text: 'Jiangsu',
value: '320000',
children: [{ text: 'Nanjing', value: '320100' }],
},
],
};
},
methods: {
onFinish(params) {
const { selectedOptions } = params;
this.fieldValue = selectedOptions.map((option) => option.text).join('/');
},
},
};
Custom Color
<van-cascader
v-model="cascaderValue"
title="Select Area"
active-color="#1989fa"
@close="show = false"
@finish="onFinish"
/>
API
Props
Attribute |
Description |
Type |
Default |
title |
Title |
string |
- |
value |
Values of selected options |
string | number |
- |
options |
Options |
Option[] |
[] |
placeholder |
Placeholder of unselected tab |
string |
Select |
active-color |
Active color |
string |
#ee0a24 |
closeable |
Whether to show close icon |
boolean |
true |
Events
Event |
Description |
Arguments |
change |
Emitted when active option changed |
{ value, selectedOptions, tabIndex } |
finish |
Emitted when all options is selected |
{ value, selectedOptions, tabIndex } |
close |
Emmitted when the close icon is clicked |
- |
Slots
Name |
Description |
title |
Custom title |
Less Variables
How to use: Custom Theme.
Name |
Default Value |
Description |
@cascader-header-height |
48px |
- |
@cascader-title-font-size |
@font-size-lg |
- |
@cascader-title-line-height |
20px |
- |
@cascader-close-icon-size |
22px |
- |
@cascader-close-icon-color |
@gray-5 |
- |
@cascader-close-icon-active-color |
@gray-6 |
- |
@cascader-selected-icon-size |
18px |
- |
@cascader-tabs-height |
48px |
- |
@cascader-active-color |
@red |
- |
@cascader-options-height |
384px |
- |
@cascader-tab-title-color |
@text-color |
- |
@cascader-unselected-tab-title-color |
@gray-6 |
- |