schangxiang@126.com
2025-09-09 528b1ae722536aafc6afce10389ce7982ed278df
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
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>