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

    react中forceupdate的用法是什么

    长期闲置长期闲置2022-04-19 12:03:35原创307

    在react中,forceupdate()用于强制使组件跳过shouldComponentUpdate(),直接调用render(),可以触发组件的正常生命周期方法,语法为“component.forceUpdate(callback)”。

    本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

    react中forceupdate的用法是什么

    仅当组件的状态或传递给它的道具发生变化时,React中的组件才会re-render,但是如果某些数据发生变化,如果我们需要更改组件的re-render,则我们将使用React的forceUpdate()方法。调用forceUpdate()将强制组件re-render,从而跳过该shouldComponentUpdate()方法而调用该组件的render()方法。

    提示:通常,避免使用forceUpdate(),而只能从render()中的this.props和this.state中读取。

    用法:

    component.forceUpdate(callback)

    虽然确实有一些使用forceUpdate()方法的用例,但最好在需要时使用挂钩,道具,状态和上下文来对组件进行re-render处理。

    默认情况下,当组件的state或props改变时,组件将重新渲染。如果你的render()方法依赖于一些其他的数据,你可以告诉React组件需要通过调用forceUpdate()重新渲染。

    调用forceUpdate()会导致组件跳过shouldComponentUpdate(),直接调用render()。这将触发组件的正常生命周期方法,包括每个子组件的shouldComponentUpdate()方法。

    forceUpdate就是重新render。有些变量不在state上,当时你又想达到这个变量更新的时候,刷新render;或者state里的某个变量层次太深,更新的时候没有自动触发render。这些时候都可以手动调用forceUpdate自动触发render

    Sub.js
    class Sub extends React.Component{
        construcotr(){
            super();
            this.name = "yema";
        }
        refChangeName(name){
            this.name = name;
            this.forceUpdate(); 
        }
        render(){
            return (<div>{this.name}</div>);
        }
    }
    App.js
    class App extends React.Component{
        handleClick(){
            this.subRef.refChangeName("yemafuren");
        }
        render(){
            return (<div>
                <Sub ref={(sub)=>{this.subRef = sub;}} />
                <button onClick={this.handleClick}>click</button>
            </div>);
        }
    }

    推荐学习:《react视频教程

    以上就是react中forceupdate的用法是什么的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:React
    上一篇:react的ssr项目是什么 下一篇:什么是es6模块化
    Web大前端开发直播班

    相关文章推荐

    • react高阶组件是什么意思• react15与16版本的不同是什么• react单页面和多页面的区别是什么• react中key的用法是什么• React路由有几种模式
    1/1

    PHP中文网