63 lines
1.2 KiB
Vue
63 lines
1.2 KiB
Vue
|
<template>
|
|||
|
<view class="wrap" :style="{height: `${height}px`}">
|
|||
|
<view class="divider" :style="[elStyle]"></view>
|
|||
|
</view>
|
|||
|
</template>
|
|||
|
|
|||
|
<script setup>
|
|||
|
/**
|
|||
|
* 分割线
|
|||
|
*/
|
|||
|
|
|||
|
import { computed } from 'vue';
|
|||
|
|
|||
|
// 接收参数
|
|||
|
const props = defineProps({
|
|||
|
// 线条颜色
|
|||
|
lineColor: {
|
|||
|
type: String,
|
|||
|
default: '#000',
|
|||
|
},
|
|||
|
// 线条样式:'dotted', 'solid', 'double', 'dashed'
|
|||
|
borderType: {
|
|||
|
type: String,
|
|||
|
default: 'dashed',
|
|||
|
},
|
|||
|
// 线条宽度
|
|||
|
lineWidth: {
|
|||
|
type: Number,
|
|||
|
default: 1,
|
|||
|
},
|
|||
|
// 高度
|
|||
|
height: {
|
|||
|
type: [Number, String],
|
|||
|
default: 'auto'
|
|||
|
},
|
|||
|
// 左右边距:none - 无边距,horizontal - 左右留边
|
|||
|
paddingType: {
|
|||
|
type: String,
|
|||
|
default: 'none'
|
|||
|
}
|
|||
|
});
|
|||
|
|
|||
|
const elStyle = computed(() => {
|
|||
|
return {
|
|||
|
'border-top-width': `${props.lineWidth}px`,
|
|||
|
'border-top-color': props.lineColor,
|
|||
|
'border-top-style': props.borderType,
|
|||
|
margin: props.paddingType === 'none' ? '0' : '0px 16px'
|
|||
|
};
|
|||
|
});
|
|||
|
</script>
|
|||
|
|
|||
|
<style lang="scss" scoped>
|
|||
|
.wrap {
|
|||
|
display: flex;
|
|||
|
align-items: center;
|
|||
|
|
|||
|
.divider {
|
|||
|
width: 100%;
|
|||
|
}
|
|||
|
}
|
|||
|
</style>
|