【Vue + ElementUI】el-progress 各类常用场景(自动计算percentage,format自定义显示文字)

本文介绍了一种使用Vue.js结合Element UI组件库实现动态进度条的方法,通过解析数据结构,自定义进度条文字,及根据不同条件设置进度条状态与颜色,实现了直观的数据展示效果。

效果图:

1. 当前数据结构

progressList: [
    {
        planNum: 150,   // 计划数量
        completeNum: 80  // 完成数量
    },
    {
        planNum: 70,
        completeNum: 70
    },
    {
        planNum: 70,
        completeNum: 90
    }
]

2. 前端代码

<div v-for="(item, index) in progressList" class="item-view">
	<el-progress :text-inside="true" :stroke-width="26" :percentage="setItemProgress(item)" v-if="!isNaN(parseInt((item.planNum/item.completeNum)*100))"
	:status="setItemStatus(item)" :format="setItemText(item)"></el-progress>
</div>

3.方法

// 设置进度
setItemProgress(data) {
    if (data.planNum > data.completeNum) {
        return 100
    } else {
        return parseInt((data.planNum / data.completeNum).toFixed(1) * 100)
    }
},

// 自定义进度条文字
setItemText(row) {
    return () => {
        return '计划: ' + row.planNum + ',完成: ' + row.completeNum
    }
},

// 设置当前进度条状态,显示不同颜色
setItemStatus(data) {
    if (data.planNum > data.completeNum) {
        return 'exception'
    } else if (data.planNum === data.completeNum) {
        return 'success'
    } else {
        return 'warning'
    }
}

完整代码:

<template>
	<div>
		<div class="content-view">
			<div v-for="(item, index) in progressList" class="item-view">
				<el-progress :text-inside="true" :stroke-width="26" :percentage="setItemProgress(item)" v-if="!isNaN(parseInt((item.planNum/item.completeNum)*100))"
				 :status="setItemStatus(item)" :format="setItemText(item)"></el-progress>
			</div>
		</div>
	</div>

</template>

<script>
	export default {
		data() {
			return {
				progressList: [{
						planNum: 150,
						completeNum: 80 
					},
					{
						planNum: 70,
						completeNum: 70
					},
					{
						planNum: 70,
						completeNum: 90
					}
				]

			}
		},

		methods: {
			setItemProgress(data) {
				if (data.planNum > data.completeNum) {
					return 100
				} else {
					return parseInt((data.planNum / data.completeNum).toFixed(1) * 100)
				}
			},

			setItemText(row) {
				return () => {
					return '计划: ' + row.planNum + ',完成: ' + row.completeNum
				}
			},

			setItemStatus(data) {
				if (data.planNum > data.completeNum) {
					return 'exception'
				} else if (data.planNum === data.completeNum) {
					return 'success'
				} else {
					return 'warning'
				}
			}
		}
	}
</script>
<style lang="scss" scoped>
	.content-view {
		height: calc(100vh - 84px);
		background-color: #FFFFFF;
		padding: 20px;
	}

	.item-view {
		margin-bottom: 1rem;
	}
</style>

 

### 如何在 Element UI 的 `el-progress` 组件中显示文字自定义文字内容 Element UI 的 `el-progress` 组件支持通过配置属性来显示文字自定义文字内容。以下是实现此功能的详细说明和代码示例。 #### 1. 显示默认文字 默认情况下,`el-progress` 会在进度条下方显示百分比文字。可以通过设置 `text-inside="true"` 将文字显示在进度条内部[^1]。 ```vue <template> <el-progress :percentage="70" text-inside status="success"></el-progress> </template> ``` #### 2. 自定义文字内容 如果需要显示自定义文字内容,可以使用 `format` 属性,并传递一个函数作为其值。该函数接收当前百分比作为参数并返回自定义文本[^2]。 ```vue <template> <el-progress :percentage="percentage" :format="customText"></el-progress> </template> <script> export default { data() { return { percentage: 70, }; }, methods: { customText(percentage) { return `${percentage}% 完成`; }, }, }; </script> ``` #### 3. 样式调整 为了进一步优化显示效果,可以结合 CSS 对文字样式进行调整。例如,更改字体大小、颜色等[^3]。 ```vue <template> <el-progress :percentage="percentage" :format="customText" color="#87d068"></el-progress> </template> <style scoped> /* 调整进度条内文字样式 */ /deep/ .el-progress__text { font-size: 14px; color: #333; } </style> ``` #### 注意事项 - 如果设置了 `text-inside="true"`,则进度条的高度必须足够大以容纳文字,否则可能会导致文字被截断。 - `color` 属性可用于设置进度条的颜色,也可以是一个函数,根据不同的百分比返回不同的颜色[^4]。 ---
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值