因为习惯了写Jquery,后面改为Vue写后,慢慢琢磨,写了一个比较简单且使用的小Demo
<div class="color_selection" style="width: 200px;height: 36px;">
<div @click="changeSelect($event)" :data-index = "index" ref="color" style="width: 47px;height: 36px;border: 1px solid #dcdfe6;">
<div class="color" style="width: 16px;height:16px;border: 1px solid #e6e6e6;line-height: 16px;position: absolute;left: 15px;top: 10px;">div>
div>
<div ref="color" @click="changeSelect($event)":data-index = "index" style="width: 47px;height: 36px;border: 1px solid #dcdfe6;">
<div class="color" style="width: 16px;height: 16px;background: #000;text-align: center;line-height: 16px;position: absolute;left: 15px;top: 10px;">div>
div>
<div @click="changeSelect($event)" :data-index ="index" ref="color" style="width: 47px;height: 36px;border: 1px solid #dcdfe6;">
<div class="color" style="width: 16px;height: 16px;background: red;text-align: center;line-height: 16px;position: absolute;left: 15px;top: 10px;">div>
div>
div>
changeSelect(ev){
var target = ev.currentTarget;
var index = ev.currentTarget.dataset.index;
for(var i = 0;i<this.$refs.color.length;i++){
var data = this.$refs.color[i];
data.setAttribute("class","color");
}
this.$nextTick(() => {
console.log(this.$refs.refContent)//有结果
target.setAttribute("class","color color_select")
})
},

Vue学习笔记 —— 使用Vue的ref实现动态添加活动类名
感谢你的观看。