文章详情页
javascript - react如何不通过state去修改classname?
浏览:99日期: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. dockerfile - 为什么docker容器启动不了?2. javascript - webapp业务流程基本一致,多套主题(样式基本不一样,交互稍有偏差)管理,并且有不断有新增主题,该如何设计组件化架构?3. javascript - ejs支持if else语法吗4. 请教各位大佬,浏览器点 提交实例为什么没有反应5. macos - mac下docker如何设置代理6. javascript - 用rem写的页面,安卓手机显示文字是正常的,苹果显示的文字是特别小的是为什么呢7. javascript - 移动端,当出现遮罩层的时候,遮罩层里有div是超出高度scroll的,怎么避免滑动div的时候,body跟随滑动?8. javascript - JS设置Video视频对象的currentTime时出现了问题,IE,Edge,火狐,都可以设置,反而chrom却...9. 新手 - Python 爬虫 问题 求助10. javascript - 学习网页开发,关于head区域一段脚本的疑惑
排行榜
