mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-22 11:54:02 +00:00 
			
		
		
		
	
		
			
				
	
	
	
		
			4.2 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			4.2 KiB
		
	
	
	
	
	
	
	
Picker
The Picker component is usually used with Popup Component.
Install
import { Picker } from 'vant';
Vue.use(Picker);
Usage
Basic Usage
<van-picker :columns="columns" @change="onChange" />
export default {
  data() {
    return {
      columns: ['Delaware', 'Florida', 'Georqia', 'Indiana', 'Maine']
    };
  },
  methods: {
    onChange(picker, value, index) {
      Toast(`Value: ${value}, Index: ${index}`);
    }
  }
};
Disable option
<van-picker :columns="columns" />
export default {
  data() {
    return {
      columns: [
        { text: 'Delaware', disabled: true },
        { text: 'Florida' },
        { text: 'Georqia' }
      ]
    };
  }
};
Show Toolbar
<van-picker
  show-toolbar
  title="Title"
  :columns="columns"
  @cancel="onCancel"
  @confirm="onConfirm"
/>
export default {
  data() {
    return {
      columns: ['Delaware', 'Florida', 'Georqia', 'Indiana', 'Maine']
    }
  },
  methods: {
    onConfirm(value, index) {
      Toast(`Value: ${value}, Index: ${index}`);
    },
    onCancel() {
      Toast('Cancel');
    }
  }
};
Multi columns
<van-picker :columns="columns" @change="onChange" />
const states = {
  'Group1': ['Delaware', 'Florida', 'Georqia', 'Indiana', 'Maine'],
  'Group2': ['Alabama', 'Kansas', 'Louisiana', 'Texas']
};
export default {
  data() {
    return {
      columns: [
        {
          values: Object.keys(states),
          className: 'column1'
        },
        {
          values: states.Group1,
          className: 'column2',
          defaultIndex: 2
        }
      ]
    };
  },
  methods: {
    onChange(picker, values) {
      picker.setColumnValues(1, states[values[0]]);
    }
  }
};
Loading
When Picker columns data is acquired asynchronously, use loading prop to show loading prompt
<van-picker :columns="columns" loading />
API
| Attribute | Description | Type | Default | 
|---|---|---|---|
| columns | Columns data | Array | [] | 
| show-toolbar | Whether to show toolbar | Boolean | false | 
| title | Toolbar title | String | '' | 
| loading | Whether to show loading prompt | Boolean | false | 
| value-key | Key of option text | String | text | 
| item-height | Option height | Number | 44 | 
| confirm-button-text | Text of confirm button | String | Confirm | 
| cancel-button-text | Text of cancel button | String | Cancel | 
| visible-item-count | Count of visible columns | Number | 5 | 
Event
Picker events will pass different parameters according to the columns are single or multiple
| Event | Description | Arguments | 
|---|---|---|
| confirm | Triggered when click confirm button | Single column:current value,current index Multiple columns:current values,current indexes | 
| cancel | Triggered when click cancel button | Single column:current value,current index Multiple columns:current values,current indexes | 
| change | Triggered when current option changed | Single column:Picker instance, current value,current index Multiple columns:Picker instance, current values,column index | 
Data struct of columns
| key | Description | 
|---|---|
| values | Value of column | 
| defaultIndex | Default value index | 
| className | ClassName for this column | 
Picker instance
You can get the picker instance in 'change' event, and
| Method | Description | 
|---|---|
| getValues() | Get current values of all columns | 
| setValues(values) | Set current values of all columns | 
| getIndexes() | Get current indexes of all columns | 
| setIndexes(indexes) | Set current indexes of all columns | 
| getColumnValue(columnIndex) | Get current value of the column | 
| setColumnValue(columnIndex, value) | Set current value of the column | 
| getColumnIndex(columnIndex) | Get current index of the column | 
| setColumnIndex(columnIndex, optionIndex) | Set current index of the column | 
| getColumnValues(columnIndex) | Get columns data of the column | 
| setColumnValues(columnIndex, values) | Set columns data of the column | 
