vue3自定义按钮点击变颜色实现(多选功能)

实现效果图: 默认选中第一个按钮,未选中按钮为粉色,点击时颜色变为红色

利用动态类名,当定义isChange数值和下标index相同时,赋予act类名,实现变色效果

复制代码
<template>
  <div class="page">
    <div class="btns" v-for="(item, index) in 6" :key="index">
      <div
        class="btn"
        :class="{ act: isChange.includes(index) }"
        @click="change(index)"
      >
        按钮{{ index + 1 }}
      </div>
    </div>
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const isChange = ref([]);
    const change = (index) => {
      if (isChange.value.includes(index)) {
        // 如果按钮已经被选中,则移除该按钮的索引值
        isChange.value = isChange.value.filter((item) => item !== index);
      } else {
        // 如果按钮未被选中,则添加该按钮的索引值
        isChange.value.push(index);
      }
    };

    return { isChange, change };
  },
};
</script>

<style>
.page {
  padding: 50px;
  display: flex;
  flex-wrap: wrap;
}

.btn {
  width: 60px;
  height: 30px;
  background-color: pink;
  margin: 10px;
}

.act {
  background-color: red;
}
</style>
相关推荐
一斤代码35 分钟前
vue3 下载图片(标签内容可转图)
前端·javascript·vue
中微子38 分钟前
React Router 源码深度剖析解决面试中的深层次问题
前端·react.js
光影少年40 分钟前
从前端转go开发的学习路线
前端·学习·golang
中微子1 小时前
React Router 面试指南:从基础到实战
前端·react.js·前端框架
3Katrina1 小时前
深入理解 useLayoutEffect:解决 UI "闪烁"问题的利器
前端·javascript·面试
前端_学习之路2 小时前
React--Fiber 架构
前端·react.js·架构
coderlin_2 小时前
BI布局拖拽 (1) 深入react-gird-layout源码
android·javascript·react.js
伍哥的传说2 小时前
React 实现五子棋人机对战小游戏
前端·javascript·react.js·前端框架·node.js·ecmascript·js
qq_424409193 小时前
uniapp的app项目,某个页面长时间无操作,返回首页
前端·vue.js·uni-app
我在北京coding3 小时前
element el-table渲染二维对象数组
前端·javascript·vue.js