日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 前端技术 > vue >内容正文

vue

vue循环出来的数据,通过点击事件改变了数据,但是视图却没有更新

發(fā)布時(shí)間:2025/4/14 vue 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 vue循环出来的数据,通过点击事件改变了数据,但是视图却没有更新 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

列表清單中,每一個(gè)列表的說明條件都只顯示一條,點(diǎn)擊實(shí)現(xiàn)折疊面板的效果,需求如下圖:

給商品添加了text和flag,點(diǎn)擊展開文字,數(shù)據(jù)進(jìn)行了更新,但是視圖沒有變化

<div class="goodsConfirm van-hairline--bottom" v-for="(item,index) in orderInfo.goods" :key="index"><div class="goodsCon ">......</div><div v-if="item.showFall || item.showFixed" :class="[item.ruleflag?'rebateRule':'rebateRulehide']" ref="rebateRule" @click="toggleRule(item)"><p class="toggleRule">{{item.rulename}}</p><p v-if="itemrule.rebateType=='BASIC_POLICY' && item.showFall" v-for="(itemrule,i) in item.fallRebateRule" :key="itemrule.rebateUid">{{itemrule.rebateName}}:【{{itemrule.rebateTypeName}}】<span v-if="itemrule.quantity>0">最高{{itemrule.quantity}}臺(tái),</span>直減{{itemrule.amount}}元</p><p v-if="itemrule.rebateType=='SPECIAL_POLICY'&& item.showFall" v-for="(itemrule,i) in item.fallRebateRule" :key="itemrule.rebateUid">{{itemrule.rebateName}}:【{{itemrule.rebateTypeName}}】<span v-if="itemrule.quantity>0">滿{{itemrule.quantity}}臺(tái),</span>每臺(tái)直減{{itemrule.amount}}元</p><p v-if="itemrule.rebateType=='BASIC_POLICY' && item.showFixed" v-for="(itemrule,i) in item.fixedRebateRule" :key="itemrule.rebateUid">{{itemrule.rebateName}}:【{{itemrule.rebateTypeName}}】<span v-if="itemrule.quantity>0">最高{{itemrule.quantity}}臺(tái),</span>直減{{itemrule.amount}}元</p><p v-if="itemrule.rebateType=='SPECIAL_POLICY'&& item.showFixed" v-for="(itemrule,i) in item.fixedRebateRule" :key="itemrule.rebateUid">{{itemrule.rebateName}}:【{{itemrule.rebateTypeName}}】<span v-if="itemrule.quantity>0">滿{{itemrule.quantity}}臺(tái),</span>每臺(tái)直減{{itemrule.amount}}元</p></div> </div> //拿到數(shù)據(jù)后進(jìn)行處理
self.orderInfo.goods.forEach((item, index) => {item.rulename='展開';
    
item.ruleflag=true;
})

//點(diǎn)擊事件

 toggleRule(obj){
  if(obj.ruleflag){
    obj.rulename='收起';
    obj.ruleflag=false;? ?
  }
  else if(!obj.ruleflag){
    obj.rulename='展開';
    obj.ruleflag=true;??
  }
 },

對于已經(jīng)創(chuàng)建的實(shí)例,Vue 不能動(dòng)態(tài)添加根級(jí)別的響應(yīng)式屬性。但是,可以使用?Vue.set(object, key, value)方法向嵌套對象添加響應(yīng)式屬性。例如:

var vm = new Vue({data: {userProfile: {name: 'Anika'}} })

你可以添加一個(gè)新的 age 屬性到嵌套的 userProfile 對象;還可以使用 vm.$set 實(shí)例方法,它只是全局 Vue.set 的別名:

Vue.set(vm.userProfile, 'age', 27) vm.$set(vm.userProfile, 'age', 27) //拿到數(shù)據(jù)后進(jìn)行處理
self.orderInfo.goods.forEach((item, index) => {item.rulename='展開';
    item.ruleflag=true;
})

//點(diǎn)擊事件

 toggleRule(obj){
  if(obj.ruleflag){
    this.$set(obj,'rulename','收起')
    this.$set(obj,'ruleflag',false)
  }
  else if(!obj.ruleflag){
    this.$set(obj,'rulename','展開')
    this.$set(obj,'ruleflag',true)
  }
 },

?

轉(zhuǎn)載于:https://www.cnblogs.com/xiao-ling-zi/p/10950282.html

總結(jié)

以上是生活随笔為你收集整理的vue循环出来的数据,通过点击事件改变了数据,但是视图却没有更新的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。