You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			JavaScript
		
	
| import { VantComponent } from '../common/component';
 | |
| import { addUnit } from '../common/utils';
 | |
| VantComponent({
 | |
|     field: true,
 | |
|     relation: {
 | |
|         name: 'radio-group',
 | |
|         type: 'ancestor',
 | |
|         linked(target) {
 | |
|             this.parent = target;
 | |
|         },
 | |
|         unlinked() {
 | |
|             this.parent = null;
 | |
|         }
 | |
|     },
 | |
|     classes: ['icon-class', 'label-class'],
 | |
|     props: {
 | |
|         value: null,
 | |
|         disabled: Boolean,
 | |
|         useIconSlot: Boolean,
 | |
|         checkedColor: String,
 | |
|         labelPosition: {
 | |
|             type: String,
 | |
|             value: 'right'
 | |
|         },
 | |
|         labelDisabled: Boolean,
 | |
|         shape: {
 | |
|             type: String,
 | |
|             value: 'round'
 | |
|         },
 | |
|         iconSize: {
 | |
|             type: null,
 | |
|             observer: 'setIconSizeUnit'
 | |
|         }
 | |
|     },
 | |
|     data: {
 | |
|         iconSizeWithUnit: '20px'
 | |
|     },
 | |
|     methods: {
 | |
|         setIconSizeUnit(val) {
 | |
|             this.setData({
 | |
|                 iconSizeWithUnit: addUnit(val)
 | |
|             });
 | |
|         },
 | |
|         emitChange(value) {
 | |
|             const instance = this.parent || this;
 | |
|             instance.$emit('input', value);
 | |
|             instance.$emit('change', value);
 | |
|         },
 | |
|         onChange(event) {
 | |
|             console.log(event);
 | |
|             this.emitChange(this.data.name);
 | |
|         },
 | |
|         onClickLabel() {
 | |
|             const { disabled, labelDisabled, name } = this.data;
 | |
|             if (!disabled && !labelDisabled) {
 | |
|                 this.emitChange(name);
 | |
|             }
 | |
|         }
 | |
|     }
 | |
| });
 |