mirror of
				https://gitee.com/vant-contrib/vant-weapp.git
				synced 2025-10-26 01:22:07 +08:00 
			
		
		
		
	feat(rate): support model value
This commit is contained in:
		
							parent
							
								
									c63e63d6e4
								
							
						
					
					
						commit
						ea1653657a
					
				| @ -7,13 +7,6 @@ Page({ | ||||
|     value3: 3, | ||||
|     value4: 2.5, | ||||
|     value5: 4, | ||||
|     value6: 3 | ||||
|     value6: 3, | ||||
|   }, | ||||
| 
 | ||||
|   onChange(event) { | ||||
|     const { key } = event.currentTarget.dataset; | ||||
|     this.setData({ | ||||
|       [key]: event.detail | ||||
|     }); | ||||
|   } | ||||
| }); | ||||
|  | ||||
| @ -1,8 +1,7 @@ | ||||
| <demo-block title="基础用法"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value1" | ||||
|     value="{{ value1 }}" | ||||
|     model:value="{{ value1 }}" | ||||
|   /> | ||||
| </demo-block> | ||||
| 
 | ||||
| @ -11,53 +10,45 @@ | ||||
|     custom-class="rate-position" | ||||
|     icon="like" | ||||
|     void-icon="like-o" | ||||
|     data-key="value2" | ||||
|     value="{{ value2 }}" | ||||
|     model:value="{{ value2 }}" | ||||
|   /> | ||||
| </demo-block> | ||||
| 
 | ||||
| <demo-block title="自定义样式"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value3" | ||||
|     value="{{ value3 }}" | ||||
|     model:value="{{ value3 }}" | ||||
|     size="{{ 25 }}" | ||||
|     color="#ee0a24" | ||||
|     void-color="#eee" | ||||
|     void-icon="star" | ||||
|     bind:change="onChange" | ||||
|   /> | ||||
| </demo-block> | ||||
| 
 | ||||
| <demo-block title="半星"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value4" | ||||
|     value="{{ value4 }}" | ||||
|     model:value="{{ value4 }}" | ||||
|     size="{{ 25 }}" | ||||
|     allow-half | ||||
|     color="#ee0a24" | ||||
|     void-color="#eee" | ||||
|     void-icon="star" | ||||
|     touchable="{{ false }}" | ||||
|     bind:change="onChange" | ||||
|   /> | ||||
| </demo-block> | ||||
| 
 | ||||
| <demo-block title="自定义数量"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value5" | ||||
|     value="{{ value5 }}" | ||||
|     model:value="{{ value5 }}" | ||||
|     count="{{ 6 }}" | ||||
|     bind:change="onChange" | ||||
|   /> | ||||
| </demo-block> | ||||
| 
 | ||||
| <demo-block title="禁用状态"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value6" | ||||
|     value="{{ value6 }}" | ||||
|     disabled | ||||
|   /> | ||||
| @ -66,7 +57,6 @@ | ||||
| <demo-block title="只读状态"> | ||||
|   <van-rate | ||||
|     custom-class="rate-position" | ||||
|     data-key="value6" | ||||
|     value="{{ value6 }}" | ||||
|     readonly | ||||
|   /> | ||||
|  | ||||
| @ -13,7 +13,7 @@ | ||||
| 	}, | ||||
| 	"compileType": "miniprogram", | ||||
| 	"cloudfunctionRoot": "functions/", | ||||
| 	"libVersion": "2.3.0", | ||||
| 	"libVersion": "2.9.3", | ||||
| 	"appid": "wx1c01b35002d3ba14", | ||||
| 	"projectname": "vant-weapp", | ||||
| 	"debugOptions": { | ||||
|  | ||||
							
								
								
									
										33
									
								
								packages/common/version.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										33
									
								
								packages/common/version.ts
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,33 @@ | ||||
| import { getSystemInfoSync } from './utils'; | ||||
| 
 | ||||
| function compareVersion(v1, v2) { | ||||
|   v1 = v1.split('.'); | ||||
|   v2 = v2.split('.'); | ||||
|   const len = Math.max(v1.length, v2.length); | ||||
| 
 | ||||
|   while (v1.length < len) { | ||||
|     v1.push('0'); | ||||
|   } | ||||
|   while (v2.length < len) { | ||||
|     v2.push('0'); | ||||
|   } | ||||
| 
 | ||||
|   for (let i = 0; i < len; i++) { | ||||
|     const num1 = parseInt(v1[i], 10); | ||||
|     const num2 = parseInt(v2[i], 10); | ||||
| 
 | ||||
|     if (num1 > num2) { | ||||
|       return 1; | ||||
|     } | ||||
|     if (num1 < num2) { | ||||
|       return -1; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   return 0; | ||||
| } | ||||
| 
 | ||||
| export function canIUseModel() { | ||||
|   const system = getSystemInfoSync(); | ||||
|   return compareVersion(system.SDKVersion, '2.9.3') >= 0; | ||||
| } | ||||
| @ -1,6 +1,7 @@ | ||||
| import { VantComponent } from '../common/component'; | ||||
| import { Weapp } from 'definitions/weapp'; | ||||
| import { commonProps, inputProps, textareaProps } from './props'; | ||||
| import { canIUseModel } from '../common/version'; | ||||
| 
 | ||||
| VantComponent({ | ||||
|   field: true, | ||||
| @ -121,7 +122,9 @@ VantComponent({ | ||||
|     }, | ||||
| 
 | ||||
|     emitChange() { | ||||
|       this.setData({ value: this.value }); | ||||
|       if (canIUseModel()) { | ||||
|         this.setData({ value: this.value }); | ||||
|       } | ||||
| 
 | ||||
|       wx.nextTick(() => { | ||||
|         this.$emit('input', this.value); | ||||
|  | ||||
| @ -1,5 +1,6 @@ | ||||
| import { VantComponent } from '../common/component'; | ||||
| import { Weapp } from 'definitions/weapp'; | ||||
| import { canIUseModel } from '../common/version'; | ||||
| 
 | ||||
| VantComponent({ | ||||
|   field: true, | ||||
| @ -64,8 +65,15 @@ VantComponent({ | ||||
|       const { score } = event.currentTarget.dataset; | ||||
|       if (!data.disabled && !data.readonly) { | ||||
|         this.setData({ innerValue: score + 1 }); | ||||
|         this.$emit('input', score + 1); | ||||
|         this.$emit('change', score + 1); | ||||
| 
 | ||||
|         if (canIUseModel()) { | ||||
|           this.setData({ value: score + 1 }); | ||||
|         } | ||||
| 
 | ||||
|         wx.nextTick(() => { | ||||
|           this.$emit('input', score + 1); | ||||
|           this.$emit('change', score + 1); | ||||
|         }); | ||||
|       } | ||||
|     }, | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user