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