vue中v-for循環(huán)選中點(diǎn)擊的元素并對(duì)該元素添加樣式操作
相信大家都會(huì)遇到這種情況:v-for循環(huán)時(shí),我只需要點(diǎn)擊到的元素做出相應(yīng)反應(yīng),其他的元素不變;但是往往所有v-for循環(huán)出的元素都會(huì)變化。如下面的代碼:我需要點(diǎn)擊到的元素添加一個(gè)類(lèi)樣式,其他元素不變,但是這樣會(huì)導(dǎo)致所有的元素都會(huì)變化
html:
<div v-for = "(item,index) in items" :class = 'addclass:isactive' @click='onclick()'>
<span>{{item.name}}</span>
</div>
css:
.addclass{
color : red;
}
js:
data:{
items :[
{
name :'apple',
price: '5$'
},
{
name:'banana',
price:"3$"
},
{
name:'pear',
price:'4$'
}
],
isactive : false
}
onclick(){
this.isactive = true
}
解決方法:使用index索引,當(dāng)點(diǎn)擊一個(gè)元素時(shí),將該元素的index索引賦給類(lèi)樣式的啟用變量,如果該變量和index相等時(shí),則啟用該類(lèi)樣式
html:
<div v-for = "(item,index) in items" :class = "isactive == index ? 'addclass' : '' " @click='onclick(index)'>
<span>{{item.name}}</span>
</div>
css:
.addclass{
color : red;
}
js:
data:{
items :[
{
name :'apple',
price: '5$'
},
{
name:'banana',
price:"3$"
},
{
name:'pear',
price:'4$'
}
],
isactive : -1
}
onclick(index){
//將點(diǎn)擊的元素的索引賦值給bian變量
this.isactive = index
}
補(bǔ)充知識(shí):v-for 遍歷數(shù)組點(diǎn)擊動(dòng)態(tài)綁定樣式
這可能是一個(gè)對(duì)于任何js開(kāi)發(fā)者來(lái)說(shuō)都非常簡(jiǎn)單的問(wèn)題,或者根本談不上被叫做“問(wèn)題”,“基操”而已。但是,很遺憾,我為此開(kāi)了個(gè)篇幅簡(jiǎn)略記錄下它,因?yàn)檫@是我處于前端開(kāi)發(fā)基礎(chǔ)階段數(shù)次阻滯過(guò)我的問(wèn)題,以下暫提供一種解決方案,后續(xù)可能補(bǔ)充。
這類(lèi)問(wèn)題多見(jiàn)于單頁(yè)面應(yīng)用(SPA)中的側(cè)邊欄、表格列等,當(dāng)我曾拿到這個(gè)需求時(shí),我以為我能用Vue中介紹的Class動(dòng)態(tài)綁定來(lái)解決,事實(shí)上的確如此,但我用錯(cuò)了,請(qǐng)看我錯(cuò)誤的解決方法:
HTML
<template>
<!-- 點(diǎn)擊某個(gè)綁定樣式 -->
<ul>
<li v-for="(data, index) in formData" :key="data.id" :class="{active: isActive}" @click="currentInfo(data, index)">name: {{data.name}},age: {{data.age}}
</li>
</ul>
</template>
JavaScript
<script>
export default {
name: 'classActive'
data() {
return {
isActive: false, // 用來(lái)判斷active樣式類(lèi)是否顯示
formData: [{
id: 1,
name: 'zhangsan',
age: 20
},{
id: 2,
name: 'lisi',
age: 21
},{
id: 3,
name: 'wangwu',
age: 22
}
}
}
methods: {
currentInfo(data, index) {
if(data.id-1 === index) { // 當(dāng)前選擇的列表項(xiàng)與列表id號(hào)相等則綁定active
this.isActive = true;
}
}
}
}
</script>
Style
<style scoped>
li {
list-style: none;
border: 1px solid #333;
}
.active {
background: light-gray;
}
</style>
好,于是我興沖沖地切回頁(yè)面看效果,結(jié)果:

當(dāng)我點(diǎn)擊其中的一行時(shí),結(jié)果所有的li都綁上了active樣式,稍微想一下,相信大家都能找到問(wèn)題所在,所有l(wèi)i的樣式都由一個(gè)isActive控制,當(dāng)我點(diǎn)擊一行,全局變量isActive變?yōu)閠ure,當(dāng)然所有的li都會(huì)綁上啦!然后我就停滯下來(lái),思索一番,想過(guò)在data數(shù)組各項(xiàng)里插入一個(gè)標(biāo)識(shí)用來(lái)單獨(dú)控制,但被我否決了,一來(lái)對(duì)象中插入屬性麻煩,二來(lái)污染數(shù)據(jù)源。于是,便有了下面我要說(shuō)的解決方法:
HTML
<template>
<!-- 點(diǎn)擊某個(gè)綁定樣式 -->
<ul>
<li v-for="(data, index) in formData" :key="data.id" :class="currentClass(index)" @click="currentInfo(index)">name: {{data.name}},age: {{data.age}}
</li>
</ul>
</template>
JavaScript
<script>
export default {
name: 'classActive'
data() {
return {
currentNumber: 0, // 用來(lái)判斷active樣式類(lèi)是否顯示
formData: [{
id: 1,
name: 'zhangsan',
age: 20
},{
id: 2,
name: 'lisi',
age: 21
},{
id: 3,
name: 'wangwu',
age: 22
}
}
}
methods: {
currentInfo(index) {
this.currentNumber = index;
},
currentClass(index) {
return [this.currentNumber == index ? 'active' : ''];
}
}
}
</script>
Style
<style scoped>
li {
list-style: none;
border: 1px solid #333;
}
.active {
background: light-gray;
}
</style>
這里,我新建一個(gè)變量空間存儲(chǔ)當(dāng)前點(diǎn)擊的列表序號(hào)index,這樣不管怎樣點(diǎn)擊,這個(gè)currentNumber永遠(yuǎn)是唯一的,那么和它相等的數(shù)組項(xiàng)也是唯一的,相等即可綁定active樣式了,看效果:

好,以上就解決了遍歷數(shù)組點(diǎn)擊動(dòng)態(tài)綁定樣式,以后我找到更好的,我會(huì)補(bǔ)充,也非常歡迎大家在評(píng)論里給出更好的建議。
以上這篇vue中v-for循環(huán)選中點(diǎn)擊的元素并對(duì)該元素添加樣式操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue結(jié)合axios實(shí)現(xiàn)restful風(fēng)格的四種請(qǐng)求方式
這篇文章主要介紹了vue結(jié)合axios實(shí)現(xiàn)restful風(fēng)格的四種請(qǐng)求方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
Element中Upload組件上傳功能實(shí)現(xiàn)(圖片和文件的默認(rèn)上傳及自定義上傳)
這篇文章主要介紹了Element中Upload組件上傳功能實(shí)現(xiàn)包括圖片和文件的默認(rèn)上傳及自定義上傳,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
詳解vue數(shù)據(jù)渲染出現(xiàn)閃爍問(wèn)題
本篇文章主要介紹了vue數(shù)據(jù)渲染出現(xiàn)閃爍問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
vue路由 遍歷生成復(fù)數(shù)router-link的例子
今天小編就為大家分享一篇vue路由 遍歷生成復(fù)數(shù)router-link的例子,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10
詳解win7 cmd執(zhí)行vue不是內(nèi)部命令的解決方法
這篇文章主要介紹了詳解win7 cmd執(zhí)行vue不是內(nèi)部命令的解決方法的相關(guān)資料,這里提供了解決問(wèn)題的詳細(xì)步驟,具有一定的參考價(jià)值,需要的朋友可以參考下2017-07-07
vue實(shí)現(xiàn)側(cè)邊欄導(dǎo)航效果
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)側(cè)邊欄導(dǎo)航效果,右側(cè)顯示對(duì)應(yīng)內(nèi)容,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-10-10
vue權(quán)限管理系統(tǒng)的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue權(quán)限管理系統(tǒng)的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01

