文章詳情頁
javascript - react如何不通過state去修改classname?
瀏覽:151日期: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獲取當前元素,再通過className設置this.getDom.className = class1回答2:
原生 JS 操作 DOM 的行為是不推薦的,如果非常需要這個能力,可以通過 ReactDOM 的 findDOMNode 方法去獲取到 DOM 節點的引用。例如這里:https://facebook.github.io/re...
但這確實是一個【打開了安全倉口】的潛在風險行為,通過原生 JS 直接修改 DOM 的操作是冗余、不安全和不符合 React 思想的,建議以 JSX 的方式考慮所要解決的問題。
回答3:肯定是有其他方法可以做到的,可以考慮classnames的包,樓上用的ref也是一個常用的方法
標簽:
JavaScript
相關文章:
1. javascript - 求助關于call和apply的問題,反柯里化2. android - 求 360瀏覽器 百度瀏覽器 搜狗瀏覽器的最新啟動類名3. css3 隱藏文本4. java - .jsp頁面用<%= %>的方式獲取數據存在一個很奇怪的問題5. vue.js - vue上傳代碼到git6. java - svn導下來的項目,web-inf下怎么沒有lib文件呀?7. css - 移動端字體適配問題8. javascript - arguments.callee9. css3-translate3d-模糊bug - 為何使用了 css3 translate3d 會導致顯示模糊?10. javascript - Angular利用 broadcast和 on實現頁面跳轉并且傳遞數據 但是跳轉后收不到數據
排行榜
