数据获取与页面刷新问题

发布于 2022-09-05 03:54:14 字数 1056 浏览 12 评论 0

//store
import {observable, action} from "mobx";
import {request} from "../utils/axios"

export default class EconomyState {

    @observable economyList;

    constructor() {
        this.economyList = [];
    }

    //列表展示
    async getEconomyList() {
        const {data} = await request(
            {method: 'get', url: '/api/economy/list'},
            {},
            {message: '获取经济信息列表失败'},
        );
        this.setEconomyList(data);
    }

    @action setEconomyList(data) {
        this.economyList = data;
    }
}
//component
@inject("store")
@observer
class EconomyMain extends Component {

    constructor(props) {
        super(props);
        this.store = this.props.store.economyState;
    }

    state = {
        option: "map",
    };

    componentWillMount() {
        this.store.getEconomyList();
    };
    
    render(){
    console.log(this.store.economyList)
    return(
    ...)
    }
}

问题就是打印出来的economyList为空,但是我打断点看了,获取到数据以后,第二次刷新页面economyList是有数据的,但是为什么没有再次打印出来,我也用了observer啊,导致我后面数据都获取不到!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

一腔孤↑勇 2022-09-12 03:54:14

已解决,存在一个异步问题

a√萤火虫的光℡ 2022-09-12 03:54:14

async getEconomyList() 仍然需要 @action 来包装

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文