mirror of
				https://github.com/youzan/vant.git
				synced 2025-10-22 20:04:09 +00:00 
			
		
		
		
	refactor(ActionBar): use setup
This commit is contained in:
		| @@ -18,47 +18,35 @@ export default createComponent({ | |||||||
|     disabled: Boolean, |     disabled: Boolean, | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|   emits: ['click'], |   setup(props, { slots }) { | ||||||
|  |     return (vm) => { | ||||||
|  |       const { type, icon, text, color, loading, disabled } = props; | ||||||
|  |  | ||||||
|   computed: { |       const { parent } = vm; | ||||||
|     isFirst() { |       const { name } = vm.$options; | ||||||
|       const prev = this.parent && this.parent.children[this.index - 1]; |       const prev = parent && parent.children[vm.index - 1]; | ||||||
|       return !prev || prev.$options.name !== this.$options.name; |       const next = parent && parent.children[vm.index + 1]; | ||||||
|     }, |       const last = !next || name !== next.$options.name; | ||||||
|  |       const first = !prev || name !== prev.$options.name; | ||||||
|  |  | ||||||
|     isLast() { |       const onClick = () => { | ||||||
|       const next = this.parent && this.parent.children[this.index + 1]; |         route(vm.$router, vm); | ||||||
|       return !next || next.$options.name !== this.$options.name; |       }; | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|  |  | ||||||
|   methods: { |  | ||||||
|     onClick(event) { |  | ||||||
|       this.$emit('click', event); |  | ||||||
|       route(this.$router, this); |  | ||||||
|     }, |  | ||||||
|   }, |  | ||||||
|  |  | ||||||
|   render() { |  | ||||||
|       return ( |       return ( | ||||||
|         <Button |         <Button | ||||||
|         class={bem([ |           class={bem([type, { last, first }])} | ||||||
|           { |  | ||||||
|             first: this.isFirst, |  | ||||||
|             last: this.isLast, |  | ||||||
|           }, |  | ||||||
|           this.type, |  | ||||||
|         ])} |  | ||||||
|           size="large" |           size="large" | ||||||
|         type={this.type} |           type={type} | ||||||
|         icon={this.icon} |           icon={icon} | ||||||
|         color={this.color} |           color={color} | ||||||
|         loading={this.loading} |           loading={loading} | ||||||
|         disabled={this.disabled} |           disabled={disabled} | ||||||
|         onClick={this.onClick} |           onClick={onClick} | ||||||
|         > |         > | ||||||
|         {this.$slots.default ? this.$slots.default() : this.text} |           {slots.default ? slots.default() : text} | ||||||
|         </Button> |         </Button> | ||||||
|       ); |       ); | ||||||
|  |     }; | ||||||
|   }, |   }, | ||||||
| }); | }); | ||||||
|   | |||||||
| @@ -19,42 +19,42 @@ export default createComponent({ | |||||||
|     iconClass: null, |     iconClass: null, | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|   emits: ['click'], |   setup(props, { slots }) { | ||||||
|  |     function genIcon() { | ||||||
|  |       const { dot, badge, icon, color, iconClass } = props; | ||||||
|  |  | ||||||
|   methods: { |       if (slots.icon) { | ||||||
|     onClick(event) { |  | ||||||
|       this.$emit('click', event); |  | ||||||
|       route(this.$router, this); |  | ||||||
|     }, |  | ||||||
|  |  | ||||||
|     genIcon() { |  | ||||||
|       if (this.$slots.icon) { |  | ||||||
|         return ( |         return ( | ||||||
|           <div class={bem('icon')}> |           <div class={bem('icon')}> | ||||||
|             {this.$slots.icon()} |             {slots.icon()} | ||||||
|             <Badge dot={this.dot} badge={this.badge} /> |             <Badge dot={dot} badge={badge} /> | ||||||
|           </div> |           </div> | ||||||
|         ); |         ); | ||||||
|       } |       } | ||||||
|  |  | ||||||
|       return ( |       return ( | ||||||
|         <Icon |         <Icon | ||||||
|           class={[bem('icon'), this.iconClass]} |  | ||||||
|           tag="div" |           tag="div" | ||||||
|           dot={this.dot} |           dot={dot} | ||||||
|           name={this.icon} |           name={icon} | ||||||
|           badge={this.badge} |           badge={badge} | ||||||
|           color={this.color} |           color={color} | ||||||
|  |           class={[bem('icon'), iconClass]} | ||||||
|         /> |         /> | ||||||
|       ); |       ); | ||||||
|     }, |     } | ||||||
|   }, |  | ||||||
|  |  | ||||||
|   render() { |     return (vm) => ( | ||||||
|     return ( |       <div | ||||||
|       <div role="button" tabindex="0" class={bem()} onClick={this.onClick}> |         role="button" | ||||||
|         {this.genIcon()} |         class={bem()} | ||||||
|         {this.$slots.default ? this.$slots.default() : this.text} |         tabindex="0" | ||||||
|  |         onClick={() => { | ||||||
|  |           route(vm.$router, vm); | ||||||
|  |         }} | ||||||
|  |       > | ||||||
|  |         {genIcon()} | ||||||
|  |         {slots.default ? slots.default() : props.text} | ||||||
|       </div> |       </div> | ||||||
|     ); |     ); | ||||||
|   }, |   }, | ||||||
|   | |||||||
| @@ -13,10 +13,10 @@ export default createComponent({ | |||||||
|     }, |     }, | ||||||
|   }, |   }, | ||||||
|  |  | ||||||
|   render() { |   setup(props, { slots }) { | ||||||
|     return ( |     return () => ( | ||||||
|       <div class={bem({ unfit: !this.safeAreaInsetBottom })}> |       <div class={bem({ unfit: !props.safeAreaInsetBottom })}> | ||||||
|         {this.$slots.default?.()} |         {slots.default?.()} | ||||||
|       </div> |       </div> | ||||||
|     ); |     ); | ||||||
|   }, |   }, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 chenjiahan
					chenjiahan