| <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> |