Vue動態(tài)添加class可能帶來的問題解讀(被覆蓋)
Vue動態(tài)添加class可能帶來的問題
使用vue的伙伴相信都會使用動態(tài)class方便修改元素樣式,
也就是下面這種
通過控制flag 的 true / false 來決定addClass 這個類是否生效
當(dāng)然,如果需求僅僅如上述圖片所述,是不會出現(xiàn)什么問題的
現(xiàn)在有一個額外的dom操作
為span 動態(tài)添加了一個類(此處 后面會著重說明場景)
例如:
為他添加一個 red 類:
下面是addRedClass方法:(this as any) 是為了解決vue3 + ts 使用$refs 報錯問題 不是本章的重點,
重點在于:
通過js dom操作為span元素添加.red類樣式
methods:{ addRedClass(){ (this as any).$refs['span'].classList.add('red') } }
以下為 vue動態(tài)class 會覆蓋掉 通過dom操作添加的class樣式 的復(fù)現(xiàn)
默認狀態(tài):
點擊 第二個按鈕 (js 為span添加類名為red的class) :
當(dāng)點擊第一個按鈕 (vue動態(tài)class)
到這里,可以發(fā)現(xiàn) 通過js 添加的red類。 在點擊vue動態(tài)class按鈕后,被覆蓋掉了,自然 red的樣式也消失了, 這顯然不是我們期待的結(jié)果,我們期待的結(jié)果應(yīng)該是 同時出現(xiàn)
class=“static red addClass”
三種情況才對
問題復(fù)現(xiàn)完畢
現(xiàn)在是解釋剛剛紅字提到的內(nèi)容:
在日常開發(fā)中,既然使用vue 開發(fā) 其實很少情況會 自己手動 通過js 使用dom 為元素添加class,但是我們除了使用vue開發(fā),還會使用一些第三方 框架輔助, 例如bootstrap等,
這些框架 可能在他本身 會通過js 操作dom 元素為其添加class 從而達到 一些樣式效果,而vue 動態(tài)class 卻會覆蓋掉本該 為bootstrap提供效果的class,從而出現(xiàn)一些 難以預(yù)料的bug
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用vue.js在頁面內(nèi)組件監(jiān)聽scroll事件的方法
今天小編就為大家分享一篇使用vue.js在頁面內(nèi)組件監(jiān)聽scroll事件的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-09-09詳解Vue的computed(計算屬性)使用實例之TodoList
本篇文章主要介紹了詳解Vue的computed(計算屬性)使用實例之TodoList,具有一定的參考價值,有興趣的可以了解一下2017-08-08詳解基于 Nuxt 的 Vue.js 服務(wù)端渲染實踐
這篇文章主要介紹了詳解基于 Nuxt 的 Vue.js 服務(wù)端渲染實踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10Vue3中引入、封裝和使用svg矢量圖的實現(xiàn)示例
SVG全稱Scalable Vector Graphics,它是網(wǎng)絡(luò)上使用最廣泛的矢量圖格式,在項目開發(fā)過程中,我們經(jīng)常會用到svg矢量圖,而且我們使用svg以后,頁面上加載的不再是圖片資源,本文將給大家介紹Vue3中引入、封裝和使用svg矢量圖的實現(xiàn)示例,需要的朋友可以參考下2024-07-07