mirror of
				https://gitee.com/vant-contrib/vant.git
				synced 2025-10-20 23:12:09 +08:00 
			
		
		
		
	feat(Form): add colon prop
This commit is contained in:
		
							parent
							
								
									911b6769e4
								
							
						
					
					
						commit
						9371bc06c8
					
				| @ -443,6 +443,18 @@ export default createComponent({ | |||||||
|         return this.vanForm[key]; |         return this.vanForm[key]; | ||||||
|       } |       } | ||||||
|     }, |     }, | ||||||
|  | 
 | ||||||
|  |     genLabel() { | ||||||
|  |       const colon = this.getProp('colon') ? ':' : ''; | ||||||
|  | 
 | ||||||
|  |       if (this.slots('label')) { | ||||||
|  |         return [this.slots('label'), colon]; | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       if (this.label) { | ||||||
|  |         return <span>{this.label + colon}</span>; | ||||||
|  |       } | ||||||
|  |     }, | ||||||
|   }, |   }, | ||||||
| 
 | 
 | ||||||
|   render() { |   render() { | ||||||
| @ -453,15 +465,15 @@ export default createComponent({ | |||||||
|       icon: this.genLeftIcon, |       icon: this.genLeftIcon, | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     if (slots('label')) { |     const Label = this.genLabel(); | ||||||
|       scopedSlots.title = () => slots('label'); |     if (Label) { | ||||||
|  |       scopedSlots.title = () => Label; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return ( |     return ( | ||||||
|       <Cell |       <Cell | ||||||
|         icon={this.leftIcon} |         icon={this.leftIcon} | ||||||
|         size={this.size} |         size={this.size} | ||||||
|         title={this.label} |  | ||||||
|         center={this.center} |         center={this.center} | ||||||
|         border={this.border} |         border={this.border} | ||||||
|         isLink={this.isLink} |         isLink={this.isLink} | ||||||
| @ -470,13 +482,13 @@ export default createComponent({ | |||||||
|         titleStyle={this.labelStyle} |         titleStyle={this.labelStyle} | ||||||
|         valueClass={bem('value')} |         valueClass={bem('value')} | ||||||
|         titleClass={[bem('label', labelAlign), this.labelClass]} |         titleClass={[bem('label', labelAlign), this.labelClass]} | ||||||
|  |         scopedSlots={scopedSlots} | ||||||
|         arrowDirection={this.arrowDirection} |         arrowDirection={this.arrowDirection} | ||||||
|         class={bem({ |         class={bem({ | ||||||
|           error: this.error || this.validateMessage, |           error: this.error || this.validateMessage, | ||||||
|           [`label-${labelAlign}`]: labelAlign, |           [`label-${labelAlign}`]: labelAlign, | ||||||
|           'min-height': this.type === 'textarea' && !this.autosize, |           'min-height': this.type === 'textarea' && !this.autosize, | ||||||
|         })} |         })} | ||||||
|         scopedSlots={scopedSlots} |  | ||||||
|         onClick={this.onClick} |         onClick={this.onClick} | ||||||
|       > |       > | ||||||
|         <div class={bem('body')}> |         <div class={bem('body')}> | ||||||
|  | |||||||
| @ -409,6 +409,7 @@ export default { | |||||||
| | label-align | Field label align, can be set to `center` `right` | *string* | `left` | | | label-align | Field label align, can be set to `center` `right` | *string* | `left` | | ||||||
| | input-align | Field input align, can be set to `center` `right` | *string* | `left` | | | input-align | Field input align, can be set to `center` `right` | *string* | `left` | | ||||||
| | error-message-align | Error message align, can be set to `center` `right` | *string* | `left` | | | error-message-align | Error message align, can be set to `center` `right` | *string* | `left` | | ||||||
|  | | colon | Whether to display `:` after label | *boolean* | *false* | | ||||||
| | validate-first | Whether to stop the validation when a rule fails | *boolean* | `false` | | | validate-first | Whether to stop the validation when a rule fails | *boolean* | `false` | | ||||||
| 
 | 
 | ||||||
| ### Events | ### Events | ||||||
|  | |||||||
| @ -437,10 +437,11 @@ export default { | |||||||
| 
 | 
 | ||||||
| | 参数 | 说明 | 类型 | 默认值 | | | 参数 | 说明 | 类型 | 默认值 | | ||||||
| |------|------|------|------| | |------|------|------|------| | ||||||
| | label-width | 表单项文本宽度,默认单位为`px` | *number \| string* | `90px` | | | label-width | 表单项 label 宽度,默认单位为`px` | *number \| string* | `90px` | | ||||||
| | label-align | 表单项文本对齐方式,可选值为 `center` `right` | *string* | `left` | | | label-align | 表单项 label 对齐方式,可选值为 `center` `right` | *string* | `left` | | ||||||
| | input-align | 输入框对齐方式,可选值为 `center` `right` | *string* | `left` | | | input-align | 输入框对齐方式,可选值为 `center` `right` | *string* | `left` | | ||||||
| | error-message-align | 错误提示文案对齐方式,可选值为 `center` `right` | *string* | `left` | | | error-message-align | 错误提示文案对齐方式,可选值为 `center` `right` | *string* | `left` | | ||||||
|  | | colon | 是否在 label 后面添加冒号 | *boolean* | *false* | | ||||||
| | validate-first | 是否在某一项校验不通过时停止校验 | *boolean* | `false` | | | validate-first | 是否在某一项校验不通过时停止校验 | *boolean* | `false` | | ||||||
| 
 | 
 | ||||||
| > 表单项的 API 参见:[Field 组件](#/zh-CN/field#api) | > 表单项的 API 参见:[Field 组件](#/zh-CN/field#api) | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ const [createComponent, bem] = createNamespace('form'); | |||||||
| 
 | 
 | ||||||
| export default createComponent({ | export default createComponent({ | ||||||
|   props: { |   props: { | ||||||
|  |     colon: Boolean, | ||||||
|     labelWidth: [Number, String], |     labelWidth: [Number, String], | ||||||
|     labelAlign: String, |     labelAlign: String, | ||||||
|     inputAlign: String, |     inputAlign: String, | ||||||
|  | |||||||
| @ -1,5 +1,22 @@ | |||||||
| // Jest Snapshot v1, https://goo.gl/fbAQLP | // Jest Snapshot v1, https://goo.gl/fbAQLP | ||||||
| 
 | 
 | ||||||
|  | exports[`colon prop 1`] = ` | ||||||
|  | <form class="van-form"> | ||||||
|  |   <div class="van-cell van-field"> | ||||||
|  |     <div class="van-cell__title van-field__label"><span>Label:</span></div> | ||||||
|  |     <div class="van-cell__value van-field__value"> | ||||||
|  |       <div class="van-field__body"><input type="text" class="van-field__control"></div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  |   <div class="van-cell van-field"> | ||||||
|  |     <div class="van-cell__title van-field__label">Custom Label:</div> | ||||||
|  |     <div class="van-cell__value van-field__value"> | ||||||
|  |       <div class="van-field__body"><input type="text" class="van-field__control"></div> | ||||||
|  |     </div> | ||||||
|  |   </div> | ||||||
|  | </form> | ||||||
|  | `; | ||||||
|  | 
 | ||||||
| exports[`error-message-align prop 1`] = ` | exports[`error-message-align prop 1`] = ` | ||||||
| <form class="van-form"> | <form class="van-form"> | ||||||
|   <div class="van-cell van-field"> |   <div class="van-cell van-field"> | ||||||
|  | |||||||
| @ -105,6 +105,20 @@ test('validate-first prop', async () => { | |||||||
|   expect(onSubmit).toHaveBeenCalledWith({ A: 'foo', B: 'foo' }); |   expect(onSubmit).toHaveBeenCalledWith({ A: 'foo', B: 'foo' }); | ||||||
| }); | }); | ||||||
| 
 | 
 | ||||||
|  | test('colon prop', () => { | ||||||
|  |   const wrapper = mountForm({ | ||||||
|  |     template: ` | ||||||
|  |       <van-form colon> | ||||||
|  |         <van-field label="Label" /> | ||||||
|  |         <van-field> | ||||||
|  |           <template #label>Custom Label</template> | ||||||
|  |         </van-field> | ||||||
|  |       </van-form> | ||||||
|  |     `,
 | ||||||
|  |   }); | ||||||
|  |   expect(wrapper).toMatchSnapshot(); | ||||||
|  | }); | ||||||
|  | 
 | ||||||
| test('label-align prop', () => { | test('label-align prop', () => { | ||||||
|   const wrapper = mountForm({ |   const wrapper = mountForm({ | ||||||
|     template: ` |     template: ` | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user