uniapp——信号值组件(vue3)

组件代码

html 复制代码
<template>
	<view>
		<view class="signals">
			<view v-for="(item, index) in signals" :key="index" class="signal" :style="item"></view>
		</view>
	</view>
</template>

<script setup>
	/**
	 * 信号格组件
	 * @description 信号格组件
	 * @property {Number}			signal			当前信号值
	 * @property {Number|String}	columnWidth		柱宽度
	 * @property {Number}			maxSignal		最大信号值
	 * @property {Number}			bisection		信号等分
	 * @property {String}			lowColor		信号低颜色
	 * @property {String}			midColor		信号中颜色
	 * @property {String}			highColor		信号高颜色
	 * @property {String}			nothingColor	信号空颜色
	 * @example <signal :signal="31"></signal>
	 */
	import {
		ref,
		watch,
		defineProps
	} from 'vue'

	const props = defineProps({
		signal: {
			type: Number,
			default: 31,
		},
		columnWidth: {
			type: [Number, String],
			default: 2,
		},
		maxSignal: {
			type: Number,
			default: 31,
		},
		bisection: {
			type: Number,
			default: 4,
		},
		lowColor: {
			type: String,
			default: '#13AD11',
		},
		midColor: {
			type: String,
			default: '#13AD11',
		},
		highColor: {
			type: String,
			default: '#13AD11',
		},
		nothingColor: {
			type: String,
			default: '#c8c9cc',
		}
	})

	const initHeight = ref(1)
	const signals = ref([])

	const doChanges = () => {
		const x = props.maxSignal / props.bisection
		let min = 0
		let max = x
		const list = []

		for (let i = 0; i < props.bisection; i++) {
			let color
			if (i === 0) {
				color = props.lowColor
			} else if (i > 0 && i < props.bisection - 1) {
				color = props.midColor
			} else if (i === props.bisection - 1) {
				color = props.highColor
			}
			list.push({
				min: Math.floor(min),
				max: Math.floor(max),
				color: color
			})
			min = max
			max += x
		}

		let color
		if (props.signal >= props.maxSignal) {
			color = props.highColor
		} else if (props.signal === 0) {
			color = props.nothingColor
		} else {
			list.forEach((items) => {
				if (props.signal >= items.min && props.signal < items.max) {
					color = items.color
				}
			})
		}

		list.forEach((items) => {
			if (props.signal >= items.min) {
				items.color = color
			} else {
				items.color = props.nothingColor
			}
		})

		signals.value = list.map((items) => ({
			width: `${props.columnWidth}px`,
			height: `${initHeight.value += 1}px`,
			backgroundColor: items.color
		}))
	}

	watch(() => [props.signal, props.columnWidth, props.maxSignal, props.bisection, props.lowColor, props.midColor, props
		.highColor, props.nothingColor
	], doChanges, {
		deep: true,
		immediate: true
	})

	doChanges()
</script>

<style lang="scss">
	.signals {
		display: flex;
		align-items: baseline;

		.signal {
			border-radius: 50rpx;
			margin: 0 1px;
		}
	}
</style>

使用代码

引入:

html 复制代码
import Signal from '@/components/signal/signal.vue'

使用:

html 复制代码
<Signal :signal="info.signal" style="margin-right: 10rpx;"></Signal>
相关推荐
00后程序员张2 小时前
从审核被拒到稳定过审,iOS 上架技术优化
android·ios·小程序·https·uni-app·iphone·webview
wendycwb5 小时前
前端城市地址根据最后一级倒推,获取各层级id的方法
前端·vue.js·typescript
终端鹿6 小时前
Vue3 模板引用 (ref):操作 DOM 与子组件实例 从入门到精通
前端·javascript·vue.js
蜡台6 小时前
Vue 打包优化
前端·javascript·vue.js·vite·vue-cli
卷帘依旧7 小时前
JavaScript中this绑定问题详解
前端·javascript
yaaakaaang8 小时前
(八)前端,如此简单!---五组结构
前端·javascript
EstherNi9 小时前
vue3仿照elementui样式的写法,并进行校验,并且有默认值的设置
javascript·elementui
gCode Teacher 格码致知9 小时前
Javascript提高:get和post等请求,对于汉字和空格信息进行编码的原则-由Deepseek产生
开发语言·前端·javascript·node.js·jquery
竹林8189 小时前
从ethers.js迁移到Viem:我在一个DeFi项目前端重构中踩过的坑
前端·javascript
Arya_aa10 小时前
网络:前端向后端发送网络请求渲染在页面上,将EasyMock中的信息用前端vue框架编写代码,最终展示在浏览器
前端·vue.js