mirror of
				https://gitee.com/sliverTwo/uniapp-gp-printer.git
				synced 2025-10-26 20:15:34 +08:00 
			
		
		
		
	新增(初始化):初始化
This commit is contained in:
		
							
								
								
									
										153
									
								
								libs/uview-ui/components/u-divider/u-divider.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										153
									
								
								libs/uview-ui/components/u-divider/u-divider.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,153 @@ | ||||
| <template> | ||||
| 	<view class="u-divider" :style="{ | ||||
| 		height: height == 'auto' ? 'auto' : height + 'rpx', | ||||
| 		backgroundColor: bgColor, | ||||
| 		marginBottom: marginBottom + 'rpx', | ||||
| 		marginTop: marginTop + 'rpx' | ||||
| 	}" @tap="click"> | ||||
| 		<view class="u-divider-line" :class="[type ? 'u-divider-line--bordercolor--' + type : '']" :style="[lineStyle]"></view> | ||||
| 		<view v-if="useSlot" class="u-divider-text" :style="{ | ||||
| 			color: color, | ||||
| 			fontSize: fontSize + 'rpx' | ||||
| 		}"><slot /></view> | ||||
| 		<view class="u-divider-line" :class="[type ? 'u-divider-line--bordercolor--' + type : '']" :style="[lineStyle]"></view> | ||||
| 	</view> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| /** | ||||
|  * divider 分割线 | ||||
|  * @description 区隔内容的分割线,一般用于页面底部"没有更多"的提示。 | ||||
|  * @tutorial https://www.uviewui.com/components/divider.html | ||||
|  * @property {String Number} half-width 文字左或右边线条宽度,数值或百分比,数值时单位为rpx | ||||
|  * @property {String} border-color 线条颜色,优先级高于type(默认#dcdfe6) | ||||
|  * @property {String} color 文字颜色(默认#909399) | ||||
|  * @property {String Number} fontSize 字体大小,单位rpx(默认26) | ||||
|  * @property {String} bg-color 整个divider的背景颜色(默认呢#ffffff) | ||||
|  * @property {String Number} height 整个divider的高度,单位rpx(默认40) | ||||
|  * @property {String} type 将线条设置主题色(默认primary) | ||||
|  * @property {Boolean} useSlot 是否使用slot传入内容,如果不传入,中间不会有空隙(默认true) | ||||
|  * @property {String Number} margin-top 与前一个组件的距离,单位rpx(默认0) | ||||
|  * @property {String Number} margin-bottom 与后一个组件的距离,单位rpx(0) | ||||
|  * @event {Function} click divider组件被点击时触发 | ||||
|  * @example <u-divider color="#fa3534">长河落日圆</u-divider> | ||||
|  */ | ||||
| export default { | ||||
| 	name: 'u-divider', | ||||
| 	props: { | ||||
| 		// 单一边divider横线的宽度(数值),单位rpx。或者百分比 | ||||
| 		halfWidth: { | ||||
| 			type: [Number, String], | ||||
| 			default: 150 | ||||
| 		}, | ||||
| 		// divider横线的颜色,如设置, | ||||
| 		borderColor: { | ||||
| 			type: String, | ||||
| 			default: '#dcdfe6' | ||||
| 		}, | ||||
| 		// 主题色,可以是primary|info|success|warning|error之一值 | ||||
| 		type: { | ||||
| 			type: String, | ||||
| 			default: 'primary' | ||||
| 		}, | ||||
| 		// 文字颜色 | ||||
| 		color: { | ||||
| 			type: String, | ||||
| 			default: '#909399' | ||||
| 		}, | ||||
| 		// 文字大小,单位rpx | ||||
| 		fontSize: { | ||||
| 			type: [Number, String], | ||||
| 			default: 26 | ||||
| 		}, | ||||
| 		// 整个divider的背景颜色 | ||||
| 		bgColor: { | ||||
| 			type: String, | ||||
| 			default: '#ffffff' | ||||
| 		}, | ||||
| 		// 整个divider的高度单位rpx | ||||
| 		height: { | ||||
| 			type: [Number, String], | ||||
| 			default: 'auto' | ||||
| 		}, | ||||
| 		// 上边距 | ||||
| 		marginTop: { | ||||
| 			type: [String, Number], | ||||
| 			default: 0 | ||||
| 		}, | ||||
| 		// 下边距 | ||||
| 		marginBottom: { | ||||
| 			type: [String, Number], | ||||
| 			default: 0 | ||||
| 		}, | ||||
| 		// 是否使用slot传入内容,如果不用slot传入内容,先的中间就不会有空隙 | ||||
| 		useSlot: { | ||||
| 			type: Boolean, | ||||
| 			default: true | ||||
| 		} | ||||
| 	}, | ||||
| 	computed: { | ||||
| 		lineStyle() { | ||||
| 			let style = {}; | ||||
| 			if(String(this.halfWidth).indexOf('%') != -1) style.width = this.halfWidth; | ||||
| 			else style.width = this.halfWidth + 'rpx'; | ||||
| 			// borderColor优先级高于type值 | ||||
| 			if(this.borderColor) style.borderColor = this.borderColor; | ||||
| 			return style; | ||||
| 		} | ||||
| 	}, | ||||
| 	methods: { | ||||
| 		click() { | ||||
| 			this.$emit('click'); | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| @import "../../libs/css/style.components.scss"; | ||||
| .u-divider { | ||||
| 	width: 100%; | ||||
| 	position: relative; | ||||
| 	text-align: center; | ||||
| 	@include vue-flex; | ||||
| 	justify-content: center; | ||||
| 	align-items: center; | ||||
| 	overflow: hidden; | ||||
| 	flex-direction: row; | ||||
| } | ||||
|  | ||||
| .u-divider-line { | ||||
| 	border-bottom: 1px solid $u-border-color; | ||||
| 	transform: scale(1, 0.5); | ||||
| 	transform-origin: center; | ||||
| 	 | ||||
| 	&--bordercolor--primary { | ||||
| 		border-color: $u-type-primary; | ||||
| 	} | ||||
| 	 | ||||
| 	&--bordercolor--success { | ||||
| 		border-color: $u-type-success; | ||||
| 	} | ||||
| 	 | ||||
| 	&--bordercolor--error { | ||||
| 		border-color: $u-type-primary; | ||||
| 	} | ||||
| 	 | ||||
| 	&--bordercolor--info { | ||||
| 		border-color: $u-type-info; | ||||
| 	} | ||||
| 	 | ||||
| 	&--bordercolor--warning { | ||||
| 		border-color: $u-type-warning; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| .u-divider-text { | ||||
| 	white-space: nowrap; | ||||
| 	padding: 0 16rpx; | ||||
| 	/* #ifndef APP-NVUE */ | ||||
| 	display: inline-flex;		 | ||||
| 	/* #endif */ | ||||
| } | ||||
| </style> | ||||
		Reference in New Issue
	
	Block a user