本文介绍: 其实这里的也可以换成普通的标签,只需要给该指定好一个css即可。的方法,而不是我们想调用的原生click方法。(具体查看“@”在vue标签中的应用)其中el-card是自带的css样式,浏览器F12开发者模式可查。@click.native是在vue中,避免vue父模块调用成了vue成子模块中的。(普通元素类似input或button按钮不用。由于div不支持:focus伪类,可通过增加。=”1″,直接使用:focus)属性使其支持css伪类。
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博客
原文地址:https://blog.csdn.net/HD243608836/article/details/135487433
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_55868.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。