• 技术文章 >web前端 >前端问答

    react怎么根据条件隐藏元素

    青灯夜游青灯夜游2022-12-27 19:08:44原创116

    实现方法:1、通过state变量来控制是否渲染元素,如果值为false则内容是直接不会渲染的;2、通过style控制display属性,当属性值为none时隐藏元素;3、通过className动态切换hide来实现元素的显示和隐藏。

    本教程操作环境:Windows7系统、react18版、Dell G3电脑。

    React控制元素显示和隐藏的方法有三种方法:

    方法一:

    第一种方法是通过此例中showElem变量来控制是否加载元素的,如果showElem为false,内容是直接不会渲染的。

    class Demo extends React.Component{
        constructor(props){
            super(props);
            this.state = {
                showElem:true
            }
        }
        render(){
            return (
                <div>
                    {
                        this.state.showElem?(
                            <div>显示的元素</div>
                        ):null
                    }
                </div>
            )
        }
    }

    方法二:

    这个方法很简单,就是通过display属性来控制元素显示和隐藏。

    class Demo extends React.Component{
        constructor(props){
            super(props);
            this.state = {
                showElem:'none'
            }
        }
        render(){
            return (
                <div style={{display:this.state.showElem}}>显示的元素</div>
            )
        }
    }

    方法三:

    通过className切换hide来实现元素的显示和隐藏。

    class Demo extends React.Component{
        constructor(props){
            super(props);
            this.state = {
                showElem:true
            }
        }
        render(){
            return (
                <div>
                    {/* 写法一 */}
                    <div className={this.state.showElem?'word-style':'word-style hide'}>显示的元素</div>
                    {/* 写法二 */}
                    <div className={`${this.state.showElem?'':'hide'} word-style`}>显示的元素</div>
                </div>
            )
        }
    }

    方法一不适合频繁控制显示隐藏的情况,因为他会重新渲染元素,比较耗费性能。在这种情况下,第二种或者第三种通过display来控制会更合理。

    方法一适合安全性高的页面,比如用户信息页面,根据不同的用户级别显示不一样的内容,这时候如果你用方法一或者方法二的话,用户如果打开network还是可以看见,因为页面还是渲染了,只是隐藏了而已。而方法一是直接不渲染用户信息的DOM元素,保证了安全性。

    【相关推荐:Redis视频教程编程教学

    以上就是react怎么根据条件隐藏元素的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:React
    上一篇:React父组件怎么调用子组件的方法 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • react怎么实现列表排序• react怎么实现浮动菜单• react启动项目报错怎么办• react中怎么设置focus• creat react app 报错怎么办
    1/1

    PHP中文网