当前位置: 首页 > 知识库问答 >
问题:

当用户单击时尝试设置状态时,超过了最大更新深度

齐嘉庆
2023-03-14

我正在尝试当用户单击列表时设置状态

当用户单击一个li标记时,我在循环中的li标记中列出了我想要更新的一些状态,但反应抛出错误。

超过了最大更新深度。当组件在组件WillUpdate或组件DidUpdate中重复调用setState时,可能会发生这种情况。React限制嵌套的数量

这是我的主要代码:

class Header extends React.Component{

constructor(props){
    super(props);
    this.showCatDetail=this.showCatDetail.bind(this);
    this.state={
        category:[],
        clk_category:[],
        detail:false
    }
}

componentDidMount() {
    fetch('http://127.0.0.1:8000/portfolio/create_category/')
        .then(response=>response.json())
        .then(categoryJson => this.setState({category: categoryJson},()=>{
            this.sortCategory()
        }))
}

showCatDetail=(e)=>{

    e.preventDefault();


    this.setState({detail:true,clk_category:JSON.parse(e.currentTarget.getAttribute('data-item'))},()=>{
        console.log(this.state.clk_category)
    });


};


sortCategory = ()=>{

    let sortArray=this.state.category;
    let swap;

    for (let i=0;i<sortArray.length;i++)
    {
        for (let j=0;j<sortArray.length;j++){

            if(sortArray[i].category_rank>sortArray[j].category_rank){
                swap=sortArray[i];
                sortArray[i]= sortArray[j];
                sortArray[j]=swap;
            }
        }

    }

    this.setState({category:sortArray})

};

render(){

    let hreflink=null;
    let redirect=null;

    if (this.state.detail){
        redirect=<Redirect to={`/category_project/${this.state.clk_category.id}`}/>
    }

    return(
        <div>
            {redirect}
            <header id="header">
                <div id="trueHeader">
                    <div className="wrapper">
                        <div className="container">
                            <div className="logo">
                                <a href={hreflink} id="logo">
                                </a>
                            </div>
                            <div className="menu_main">
                                <div className="navbar yamm navbar-default">
                                    <div className="container">
                                        <div className="navbar-header">
                                            <div className="visibledevice">
                                                <ul className="nav navbar-nav">
                                                    <li><a href={hreflink} className="active">
                                                        <i className="fa fa-home">
                                                        </i> Home</a></li>
                                                </ul>
                                            </div>
                                        </div>
                                        <div className="navbar-collapse collapse pull-right">
                                            <ul className="nav navbar-nav">
                                                <li><a href={hreflink} className="active">
                                                    <i className="fa fa-home">
                                                    </i> Contact Us</a></li>
                                                {this.state.category.map(cat=>{
                                                    return(
                                                        <li data-item={JSON.stringify(cat)} onClick={(e)=>this.showCatDetail(e)}><a href={hreflink} >
                                                            <i className="fa fa-home">
                                                            </i>{cat.category_name}</a></li>
                                                    )
                                                })}
                                            </ul>
                                        </div>

                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </header>
        </div>
    )
}

}

我想不出来是什么问题…

共有1个答案

孟花蜂
2023-03-14

onClick={(e)=

在onclick中试试这个

 类似资料:
  • const[number, setNum]=useState(0);当我想添加和更改它时,我收到了这个错误(setNum(number 1))。我的错误:超过了最大更新深度。当组件在组件WillUpdate或组件DiUpdate中重复调用setState时,可能会发生这种情况。React限制嵌套更新的数量以防止无限循环。我能做些什么来解决这个问题?

  • 我收到错误消息: “超出了最大更新深度。当组件重复调用组件内部的 setState 时,可能会发生这种情况“组件将更新”或“组件更新”。React 限制了嵌套更新的数量,以防止无限循环。 我试图做的是在我从服务器(因此是开关)获得特定结果时更新状态。 每次您收到特定响应时,最终结果都应该显示不同的消息。

  • 超过了最大更新深度。当组件重复调用组件WillUpdate或组件DidUpdate中的setState时,可能会发生这种情况。React限制嵌套更新的数量以防止无限循环。 这是bossinfo.js 这是user.redux.js 你为什么一直报告这个问题?这是指向错误的方向吗?寻求帮助

  • 当我试图设置表单错误对象时,我遇到了这个问题。基本上,我想在每个输入字段下方显示错误。作为回应,我得到了一个对象数组,我如何设置我的错误对象? 错误-超过了最大更新深度。当组件在useEffect内部调用setState,但useEffect没有依赖关系数组,或者每次呈现时依赖关系之一发生变化时,就会发生这种情况。

  • 我遇到一个错误: 超过了最大更新深度。当组件重复调用componentWillUpdate或componentDidUpdate内部的setState时,会发生这种情况。React限制嵌套更新的数量,以防止无限循环。 我的代码是: 我有另一个使用路由器切换页面的组件,以及一个包含登录页面的邮件组件。

  • 当我运行我的代码时,我收到了这个错误。 超过了最大更新深度。当组件重复调用组件WillUpdate或组件DidUpdate中的setState时,可能会发生这种情况。React限制嵌套更新的数量以防止无限循环。 这是代码。它在引用。 我按照React网站上的文章所说的方式设置了我的东西,它“来了”于这个简洁的控制台类型,这就是我产生上述代码的地方。我对React、JSX和Javascript(以及