微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

尝试使用来自 API 的 Mobx 显示数据

如何解决尝试使用来自 API 的 Mobx 显示数据

我正在制作显示来自 API 的硬币数据的 React 应用程序。 我用 useEffect 做到了,而且效果很好,但现在我正在尝试使用 Mobx 做同样的事情。 我试图创建一个存储文件,从 API 获取数据并存储它,然后将其传递给 App.js,然后在屏幕上显示数据。

我是 Mobx 的新手。请帮我解决我的问题

这是我的使用效果

useEffect(() => {
    axios.get('https://api.coingecko.com/api/v3/coins/markets?vs_currency=usd&order=market_cap_desc&per_page=100&page=1&sparkline=false')
      .then(res => {
        setCoins(res.data)
        console.log(res.data)
      }).catch(error => console.log(error))
  },[]);

如何在 Store.js 文件中将此 useEffect 转换为 Mobx? 第一步,我只想显示硬币的名称

谢谢!

解决方法

结构应该是这样的:

// Coins Store file
type Coin = {
  name: string;
}

export class CointStore {
  // not sure what is your coins data type,lets assume this is array 
  readonly coins = observable<Coin>([]);

  constructor() {
    makeAutoObservable(this);
  }

  getCoins() {
    return axios.get('https://api.coingecko.com/api/v3/coins/markets')
       .then(response => this.coins.replace(response.data);
  }
}

...

// this is app.js file

import {observer} from 'mobx-react-lite'
import {createContext,useContext,useEffect} from "react"
import {CointStore} from './CointStore'

const CoinsContext = createContext<CointStore>()

const CoinsView = observer(() => {
  const coinStore = useContext(CoinsContext);

  useEffect(() => {
    coinStore.getCoins()
  },[]);

  return (
    <span>
      {coinStore.coins.map(coin => <span>{coin.name}</span>)}
    </span>
  )
})

ReactDOM.render(
  <CoinsContext.Provider value={new CointStore()}>
    <CoinsView />
  </CoinsContext.Provider>,document.body
)

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。