uni、js——点击与禁用(不可点击)、动态样式class

案例

没约满的时间可以点击进行选择,约满的就不能选择了。选择完之后变色变字。

核心思想就是创建一个第三方变量存起来,点击谁就存到第三方,在根据这个进行判断。

代码

javascript 复制代码
<template>
	<view class="content">
		<view class="list">
			<block v-for="(item,index) in list" :key="index">
				<view @click="change(item)" :class="{
					'item':true,
					'orangeBg': item.id === checkMonth.id,
					'garyBg': item.display===0,
					'blueBg': item.display===1}">
					<view>{{item.time}}</view>
					<!-- 写法一 -->
					<!-- <view>{{item.id === checkMonth.id?'已选择':item.display == 0?'约满':'可约'}}</view> -->
					<!-- 写法二 -->
					<view v-if="item.id === checkMonth.id">已选择</view>
					<view v-else>{{item.display == 0?'约满':'可约'}}</view>
				</view>
			</block>
		</view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				type: 1,
				list: [ {
					id: 1,
					time: "00:30",
					display: 1
				}, {
					id: 2,
					time: "01:00",
					display: 0
				}, {
					id: 3,
					time: "01:30",
					display: 1
				}, {
					id: 4,
					time: "02:00",
					display: 1
				}, {
					id: 5,
					time: "02:30",
					display: 1
				},{
					id: 6,
					time: "03:00",
					display: 0
				}],
				checkMonth: {}, //·选中的年月份
			}
		},
		onLoad(options) {
			this.type = options.type
		},
		methods: {
			change(item) {
				if (!item.display) {
					uni.showToast({
						title:"不可点击,点击也没效果",
						icon:'error',
						duration:400
					})
					return
				}
				console.log("可点击");
				this.checkMonth = item //当前选中的模块
				console.log(this.checkMonth);
			}
		}
	}
</script>

<style>
	.list {
		width: 800rpx;
		display: flex;
		align-items: center;
		flex-wrap: wrap;
	}

	.item {
		width: 200rpx;
		height: 200rpx;
		border: 1px solid red;
	}

	.grayBg {
		background-color: #cccccc;
	}

	.blueBg {
		background-color: skyblue;
	}

	.orangeBg {
		background-color: #FE9202;
	}
</style>

点击与禁用

javascript 复制代码
if (!item.display) {
	uni.showToast({
		title:"不可点击,点击也没效果",
		icon:'error',
		duration:400
	})
	return
}

点击之后,满足禁用条件直接return

动态样式

javascript 复制代码
:class="{
	'item':true,
	'orangeBg': item.id === checkMonth.id,
	'garyBg': item.display===0,
	'blueBg': item.display===1
}"
值为true的代表,这个样式一直存在【比如该item样式内含宽高等的固定样式】
2、3、4行为 满足条件的即显示对应的样式
相关推荐
雪碧聊技术29 分钟前
前端VUE3项目部署到linux服务器(CentOS 7)
前端·linux部署vue3项目
酒尘&6 小时前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
学历真的很重要7 小时前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
用户47949283569158 小时前
"讲讲原型链" —— 面试官最爱问的 JavaScript 基础
前端·javascript·面试
用户47949283569158 小时前
2025 年 TC39 都在忙什么?Import Bytes、Iterator Chunking 来了
前端·javascript·面试
大怪v9 小时前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范
狂炫冰美式9 小时前
不谈技术,搞点文化 🧀 —— 从复活一句明代残诗破局产品迭代
前端·人工智能·后端
xw510 小时前
npm几个实用命令
前端·npm
!win !10 小时前
npm几个实用命令
前端·npm
代码狂想家10 小时前
使用openEuler从零构建用户管理系统Web应用平台
前端