226 lines
4.7 KiB
Vue
Raw Permalink Normal View History

2025-03-10 13:49:13 +08:00
<template>
<view :class="[
'uni-tag--' + type,
disabled === true || disabled === 'true' ? 'uni-tag--disabled' : '',
inverted === true || inverted === 'true' ? type + '-uni-tag--inverted' : '',
circle === true || circle === 'true' ? 'uni-tag--circle' : '',
mark === true || mark === 'true' ? 'uni-tag--mark' : '',
'uni-tag--' + size
]" @click="onClick()" class="uni-tag" v-if="text">
<text :class="[type === 'default' ? 'uni-tag--default':'uni-tag-text',inverted === true || inverted === 'true' ? 'uni-tag-text--'+type : '',size === 'small' ? 'uni-tag-text--small':'' ]">{{ text }}</text>
</view>
</template>
<script>
/**
* Tag 标签
* @description 用于展示1个或多个文字标签可点击切换选中不选中的状态
* @tutorial https://ext.dcloud.net.cn/plugin?id=35
* @property {String} text 标签内容
* @property {String} size = [normal|small] 大小尺寸
* @value normal 正常
* @value small 小尺寸
* @property {String} type = [default|primary|successwarningerrorroyal] 颜色类型
* @value default 灰色
* @value primary 蓝色
* @value success 绿色
* @value warning 黄色
* @value error 红色
* @value royal 紫色
* @property {Boolean} disabled = [true|false] 是否为禁用状态
* @property {Boolean} inverted = [true|false] 是否无需背景颜色空心标签
* @property {Boolean} circle = [true|false] 是否为圆角
* @event {Function} click 点击 Tag 触发事件
*/
export default {
name: "UniTag",
props: {
type: {
// 标签类型default、primary、success、warning、error、royal
type: String,
default: "default"
},
size: {
// 标签大小 normal, small
type: String,
default: "normal"
},
// 标签内容
text: {
type: String,
default: ""
},
disabled: {
// 是否为禁用状态
type: [Boolean, String],
default: false
},
inverted: {
// 是否为空心
type: [Boolean, String],
default: false
},
circle: {
// 是否为圆角样式
type: [Boolean, String],
default: false
},
mark: {
// 是否为标记样式
type: [Boolean, String],
default: false
}
},
methods: {
onClick() {
if (this.disabled === true || this.disabled === "true") {
return;
}
this.$emit("click");
}
}
};
</script>
<style scoped>
.uni-tag {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
padding: 0px 16px;
height: 30px;
line-height: 30px;
justify-content: center;
color: #333;
border-radius: 3px;
background-color: #f8f8f8;
border-width: 1rpx;
border-style: solid;
border-color: #f8f8f8;
}
.uni-tag--circle {
border-radius: 15px;
}
.uni-tag--mark {
border-top-left-radius: 0;
border-bottom-left-radius: 0;
border-top-right-radius: 15px;
border-bottom-right-radius: 15px;
}
.uni-tag--disabled {
opacity: 0.5;
}
.uni-tag--small {
height: 20px;
padding: 0px 8px;
line-height: 20px;
font-size: 12px;
}
.uni-tag--default {
color: #333;
font-size: 14px;
}
.uni-tag-text--small {
font-size: 12px !important;
}
.uni-tag-text {
color: #fff;
font-size: 14px;
}
.uni-tag-text--primary {
color: #007aff !important;
}
.uni-tag-text--success {
color: #4cd964 !important;
}
.uni-tag-text--warning {
color: #f0ad4e !important;
}
.uni-tag-text--error {
color: #dd524d !important;
}
.uni-tag--primary {
color: #fff;
background-color: #007aff;
border-width: 1rpx;
border-style: solid;
border-color: #007aff;
}
.primary-uni-tag--inverted {
color: #007aff;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #007aff;
}
.uni-tag--success {
color: #fff;
background-color: #4cd964;
border-width: 1rpx;
border-style: solid;
border-color: #4cd964;
}
.success-uni-tag--inverted {
color: #4cd964;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #4cd964;
}
.uni-tag--warning {
color: #fff;
background-color: #f0ad4e;
border-width: 1rpx;
border-style: solid;
border-color: #f0ad4e;
}
.warning-uni-tag--inverted {
color: #f0ad4e;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #f0ad4e;
}
.uni-tag--error {
color: #fff;
background-color: #dd524d;
border-width: 1rpx;
border-style: solid;
border-color: #dd524d;
}
.error-uni-tag--inverted {
color: #dd524d;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #dd524d;
}
.uni-tag--inverted {
color: #333;
background-color: #ffffff;
border-width: 1rpx;
border-style: solid;
border-color: #f8f8f8;
}
</style>