elementUI点击el-card选中变色,且点击别的空白处不变色

1. <script>的data中添加属性:

复制代码
selectIndex: 0

2.<template>中添加el-card元素:

@click.native调用原生click方法。

@click.native是在vue中,避免vue父模块调用成了vue成子模块中的**this.emit('click', value)**的方法,而不是我们想调用的原生click方法。(具体查看"@"在vue标签中的应用)

  • 当点击某元素时,selectedIndex设置成当前元素的index,":class"动态css方式 给当前元素增加一个active的class样式。
  • 如果点击别的元素时,index会改变,则当前元素的**":class"动态css方式** 会自动计算去除active样式。新点击的元素会增加active的class样式。
  • 当点击别的空白处时,由于index不变,所以active样式会一直保留。
复制代码
<el-card
 :class="selectedIndex === index ? 'active':''"
 @click.native="selectedIndex = index"
 v-for="(item, index) in itemList"
 :key="index">

<div>你的内容</div>

</el-card>

3.<style>中添加样式:

其中el-card是<el-card>自带的css样式,浏览器F12开发者模式可查。

复制代码
.el-card.active {
  color:#0C5ACF;
  border: 1.5px solid #5a81fe;
}

其实这里的<el-card>也可以换成普通的<div>标签,只需要给该<div>指定好一个css即可。

补充

如果要点击选中变色,点击别处颜色消失的效果,则:

由于div不支持:focus伪类,可通过增加tabIndex="1" 属性使其支持css伪类**:focus**

(普通元素类似input或button按钮不用 tabindex="1",直接使用:focus)

复制代码
.el-card:focus {
  color:#0C5ACF;
  border: 1.5px solid #5a81fe;
}

参考:

css元素点击后变色,且点击别的地方不会颜色消失_css中点击后变色且不消失-CSDN博客

相关推荐
狼性书生9 小时前
uniapp实现的简约美观的星级评分组件
前端·uni-app·vue·组件
宇宙的最后一粒尘埃19 小时前
Typeerror: cannot read properties of undefined (reading ‘XXX‘)
vue
清幽竹客1 天前
vue-18(使用 Vuex 插件实现高级功能)
前端·vue.js·前端框架·vue
牧码岛2 天前
Web前端之隐藏元素方式的区别、Vue循环标签的时候在同一标签上隐藏元素的解决办法、hidden、display、visibility
前端·css·vue·html·web·web前端
MINO吖2 天前
基于 qiankun + vite + vue3 构建微前端应用实践
vue·vite·微前端·qiankun·single-spa
Luffe船长2 天前
elementUI点击浏览table所选行数据查看文档
javascript·elementui·vue
IT瘾君2 天前
JavaWeb:前端工程化-ElementPlus
前端·elementui·node.js·vue
sunbyte4 天前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | Dad Jokes(冷笑话卡片)
前端·javascript·css·vue.js·vue
幽络源小助理4 天前
SpringBoot+Vue+微信小程序校园自助打印系统
java·spring boot·微信小程序·小程序·vue
霸王蟹6 天前
从前端工程化角度解析 Vite 打包策略:为何选择 Rollup 而非 esbuild。
前端·笔记·学习·react.js·vue·rollup·vite