文章詳情頁
javascript - react如何不通過state去修改classname?
瀏覽:64日期:2023-02-13 17:49:59
問題描述
如題,react中怎么樣可以不用下面這種方式去改變class,直接用原生js去改變class?
<p className={ this.state.*** ? class1 : class2 }></p>
問題解答
回答1:<p ref={(p)=>{this.getDom = p}}></p>...// 可以在一個事件中通過this.getDom獲取當(dāng)前元素,再通過className設(shè)置this.getDom.className = class1回答2:
原生 JS 操作 DOM 的行為是不推薦的,如果非常需要這個能力,可以通過 ReactDOM 的 findDOMNode 方法去獲取到 DOM 節(jié)點的引用。例如這里:https://facebook.github.io/re...
但這確實是一個【打開了安全倉口】的潛在風(fēng)險行為,通過原生 JS 直接修改 DOM 的操作是冗余、不安全和不符合 React 思想的,建議以 JSX 的方式考慮所要解決的問題。
回答3:肯定是有其他方法可以做到的,可以考慮classnames的包,樓上用的ref也是一個常用的方法
標(biāo)簽:
JavaScript
相關(guān)文章:
1. 數(shù)據(jù)庫 - mysql boolean型無法插入true2. .......3. node.js - 在搭建vue.js時,安裝淘寶npm鏡像cnpm,報錯,如何解決呢4. 視頻 - html5 video的autoplay 在智能手機上不運作?5. javascript - jquery選擇的dom元素如何更新?6. python - Django問題 ’WSGIRequest’ object has no attribute ’user’7. python - scrapy中返回函數(shù)的返回值8. javascript - H5頁面無縫輪播9. mysql輸入賬號密碼后跳出一大堆內(nèi)容后但卻進(jìn)不了mysql?10. mysql服務(wù)無法啟動1067錯誤,誰知道正確的解決方法?
排行榜

熱門標(biāo)簽