You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
153 lines
4.0 KiB
153 lines
4.0 KiB
<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>
|
|
|