爱编程的设计师 2022-10-12 21:37 采纳率: 94.4%
浏览 18
已结题

为什么打印this显示state正常,单独打印state,值却为空,这是什么情况

问题遇到的现象和发生背景
用代码块功能插入代码,请勿粘贴截图
我的解答思路和尝试过的方法

img

我想要达到的结果
import React from "react";
import Search from "./Search/Search";
import Content from "./Content/Content";
import './App.css'
export default class App extends React.Component {
  state = {value:''}
  showDate = (date) => {
    this.setState({value:date});
    console.log(this.state);
    console.log(this);
  }
  render() {
    return (
      <div className="home">
        <Search showDate={this.showDate} />
        <Content date = {this.state.value} />
      </div>
    );
  }
}


![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/858738185566162.png "#left")


img

  • 写回答

2条回答 默认 最新

  • 你好!机器人 2022-10-13 08:45
    关注

    setState的异步问题,加个setTimeout或者回调

    import React from "react";
    import Search from "./Search/Search";
    import Content from "./Content/Content";
    import './App.css'
    export default class App extends React.Component {
      state = {value:''}
      showDate = (date) => {
        this.setState({value:date});
        setTimeout(()=>{
           console.log(this.state);
        })
       
        console.log(this);
      }
      render() {
        return (
          <div className="home">
            <Search showDate={this.showDate} />
            <Content date = {this.state.value} />
          </div>
        );
      }
    }
     
     
    ![img](https://img-mid.csdnimg.cn/release/static/image/mid/ask/858738185566162.png "#left")
     
     
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月21日
  • 已采纳回答 10月13日
  • 修改了问题 10月12日
  • 创建了问题 10月12日

悬赏问题

  • ¥15 抖音咸鱼付款链接转码支付宝
  • ¥15 ubuntu22.04上安装ursim-3.15.8.106339遇到的问题
  • ¥15 求螺旋焊缝的图像处理
  • ¥15 blast算法(相关搜索:数据库)
  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了