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.
		
		
		
		
		
			
		
			
	
	
		
			69 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
		
		
			
		
	
	
			69 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			JavaScript
		
	
| 
											2 years ago
										 | import { link } from '../mixins/link'; | ||
|  | import { VantComponent } from '../common/component'; | ||
|  | import { addUnit } from '../common/utils'; | ||
|  | VantComponent({ | ||
|  |     relation: { | ||
|  |         name: 'grid', | ||
|  |         type: 'ancestor', | ||
|  |         linked(parent) { | ||
|  |             this.parent = parent; | ||
|  |         } | ||
|  |     }, | ||
|  |     mixins: [link], | ||
|  |     props: { | ||
|  |         icon: String, | ||
|  |         dot: Boolean, | ||
|  |         info: null, | ||
|  |         text: String, | ||
|  |         useSlot: Boolean | ||
|  |     }, | ||
|  |     mounted() { | ||
|  |         this.updateStyle(); | ||
|  |     }, | ||
|  |     methods: { | ||
|  |         updateStyle() { | ||
|  |             if (!this.parent) { | ||
|  |                 return; | ||
|  |             } | ||
|  |             const { data, children } = this.parent; | ||
|  |             const { columnNum, border, square, gutter, clickable, center } = data; | ||
|  |             const width = `${100 / columnNum}%`; | ||
|  |             const styleWrapper = []; | ||
|  |             styleWrapper.push(`width: ${width}`); | ||
|  |             if (square) { | ||
|  |                 styleWrapper.push(`padding-top: ${width}`); | ||
|  |             } | ||
|  |             if (gutter) { | ||
|  |                 const gutterValue = addUnit(gutter); | ||
|  |                 styleWrapper.push(`padding-right: ${gutterValue}`); | ||
|  |                 const index = children.indexOf(this); | ||
|  |                 if (index >= columnNum) { | ||
|  |                     styleWrapper.push(`margin-top: ${gutterValue}`); | ||
|  |                 } | ||
|  |             } | ||
|  |             let contentStyle = ''; | ||
|  |             if (square && gutter) { | ||
|  |                 const gutterValue = addUnit(gutter); | ||
|  |                 contentStyle = `
 | ||
|  |           right: ${gutterValue}; | ||
|  |           bottom: ${gutterValue}; | ||
|  |           height: auto; | ||
|  |         `;
 | ||
|  |             } | ||
|  |             this.setData({ | ||
|  |                 style: styleWrapper.join('; '), | ||
|  |                 contentStyle, | ||
|  |                 center, | ||
|  |                 border, | ||
|  |                 square, | ||
|  |                 gutter, | ||
|  |                 clickable | ||
|  |             }); | ||
|  |         }, | ||
|  |         onClick() { | ||
|  |             this.$emit('click'); | ||
|  |             this.jumpLink(); | ||
|  |         } | ||
|  |     } | ||
|  | }); |