• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

ios - 如何使用 native react 在 AsyncStorage block 中设置状态?

[复制链接]
菜鸟教程小白 发表于 2022-12-13 14:28:15 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

我想要 AsyncStorage block 中的 setState,但出现错误:undefined is not an object(evaluation 'this.setState')

constructor(props){
    super(props);
    this.state={
        activeID:this.props.data.channel[0].id
    };
}

componentDidMount() {
    AsyncStorage.getItem(this.props.data.type,function(errs,result){
        if (!errs) {
            if (result !== null) {
                this.setState({activeID:result});
            }
        }
    });
}

_buttonPressed = (id,name,index) => {
    this.setState({activeID:id});

    AsyncStorage.setItem(this.props.data.type,id,function(errs){
     if (errs) {
       console.log('error');
     }
     if (!errs) {
       console.log('succeed');
     }
 });
}

任何帮助将不胜感激,谢谢。



Best Answer-推荐答案


这是一个绑定(bind)问题。请尝试以下操作:

componentDidMount() {
    AsyncStorage.getItem(this.props.data.type, (errs,result) => {
        if (!errs) {
            if (result !== null) {
                this.setState({activeID:result});
            }
         }
    })
 }

这样做的原因是使用 function 说明符声明的函数创建了自己的上下文,即 this 的值不是您的组件的实例.但是“胖箭头”函数不会创建新的上下文,因此您可以使用里面的所有方法。您也可以 bind 函数以保留上下文,但在这种情况下,我认为此解决方案更简洁。

关于ios - 如何使用 native react 在 AsyncStorage block 中设置状态?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41114460/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap