在我看来,我希望使用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
复制相似问题