gpt4 book ai didi

javascript - 如何在 react 中显示加载程序。使用钩子(Hook)

转载 作者:行者123 更新时间:2023-12-01 16:04:33 24 4
gpt4 key购买 nike

我正在使用 axios 与服务器进行通信。我想在用户向服务器请求时显示加载程序,并在请求完成时隐藏加载程序

所以我制作了一个自定义组件来完成此任务。但是当我多次单击同一个按钮时我的 UI 挂起

const Loader = () => {
const { loadingCount } = useLoadingState(),
{showLoading, hideLoading} = useLoadingActions();

useEffect(()=>{
const self = this
axios.interceptors.request.use(function (config) {
showLoading();
return config
}, function (error) {
return Promise.reject(error);
});

axios.interceptors.response.use(function (response) {
// spinning hide
// self.props.loading(false)
hideLoading()
return response;
}, function (error) {
hideLoading();
return Promise.reject(error);
});
})


return (
<div>
{loadingCount > 0 ?<div style={{position:"fixed",display:"flex",justifyContent:"center",alignItems:"center",width:'100%',height:'100%',zIndex:999999}}>
{/*{loadingCount > 0 ? */}
<Spin tip="Loading..." style={{zIndex:999999}}></Spin>
{/*: null}*/}
</div>: null}
</div>





);
};

问题出在 useeffect

当我注释掉 useEffect 代码时,它完美地工作。

注意:显示加载和隐藏加载会增加和减少加载次数。

我想我已经在卸载组件时释放了 axios 对象。???

最佳答案

将空数组添加到 useEffect 的 sencod 参数中。
它的工作原理类似于功能组件中的 componentDidMount()

const { useState, useEffect } = React;

const Counter = () => {
const [count, setCount] = useState(0)
const [isLoaded, setIsLoaded] = useState(false);

useEffect(() => {
setTimeout(() => {
setIsLoaded(true);
}, 3000);
}, []); // here

return (
<div>
{
isLoaded &&
<div>
<p>You clicked {count} times</p>
<button onClick={() => setCount(count + 1)}>
Click me
</button>
</div>
}
</div>
)
}

ReactDOM.render(<Counter />, document.getElementById('app'))
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.7.0-alpha.2/umd/react.development.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.7.0-alpha.2/umd/react-dom.production.min.js"></script>
<div id="app"></div>

关于javascript - 如何在 react 中显示加载程序。使用钩子(Hook),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59474818/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com