在我看来,我希望使用mobx来保存一个名为掩码的状态,当我使用axios时,这个状态将是真的,当我结束调用时,这个状态将是假的,下面是我的代码。
store.tsx
import { makeAutoObservable, runInAction } from 'mobx';
import axios from 'axios';
class Store {
isHeaderShow = false;
isTabBarShow = false;
isShowingMovies = [];
isShowingMovieIds = [];
willShowingMovies = [];
willShowingMovieIds = [];
isLoading = false;
constructor() {
    makeAutoObservable(this);
}
getShowingMovies = async () => {
    if (this.isShowingMovies.length === 0) {
        this.isLoading = true;
        let res = await axios.get(`http://localhost:3000/movie/ajax/movieOnInfoList`).then((res) => {
            return res.data;
            this.isLoading = false;
        })
        runInAction(() => {
            this.isShowingMovies = res.movieList;
            this.isShowingMovieIds = res.movieIds;
           
        })
    }
}
}
    const store = new Store();
    
    export default storemask.tsx
import React, { useState, FC } from 'react'
import { Mask } from 'antd-mobile'
import store from '../../mobx/store'
import { observer } from 'mobx-react';
const SimpleMask: FC = () => {
    const [visible, setVisible] = useState(false)
    setVisible(store.isLoading);
    return (
        <>
            <Mask visible={visible} />
        </>
    )
}
export default observer(SimpleMask)App.tsx
import React from 'react';
import './App.css';
import Header from './component/header'
import Footer from './component/footer'
import Mask from './component/mark'
function App() {
  return (
    <div className="container">
      <div className='header'>
        <Header />
      </div>
      <div className='main'>This is main</div>
      <div className='footer'>
        <Footer />
      </div>
      <Mask/>
    </div>
  );
}
export default App;package.json
"dependencies": {
    "@testing-library/jest-dom": "^5.16.2",
    "@testing-library/react": "^12.1.3",
    "@testing-library/user-event": "^13.5.0",
    "@types/jest": "^27.4.1",
    "@types/node": "^16.11.26",
    "@types/react": "^17.0.39",
    "@types/react-dom": "^17.0.13",
    "antd-mobile": "^5.4.0",
    "axios": "^0.26.0",
    "mobx": "^6.4.2",
    "mobx-react": "^7.3.0",
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-scripts": "5.0.0",
    "typescript": "^4.6.2",
    "web-vitals": "^2.1.4"
  },错误在错误信息以下
你们能给我一些建议吗?我首先使用的是react和mobx,并希望改进。非常感谢你!
发布于 2022-03-10 08:27:00
在您的setVisible组件中直接调用Mask,这将导致重呈现,这将导致再次调用setVisible,无限循环继续进行。
您可以这样做,以便只在store.isLoading在useEffect的帮助下实际更改时更新状态。
const SimpleMask: FC = () => {
    const [visible, setVisible] = useState(false)
    
    useEffect(() => {
      setVisible(store.isLoading)
    }, [store.isLoading])
    return (
        <Mask visible={visible} />
    )
}或者您可以跳过useState,直接使用您的商店:
const SimpleMask: FC = () => {
    return (
        <Mask visible={store.isLoading} />
    )
}https://stackoverflow.com/questions/71396104
复制相似问题