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