如何每 X 秒刷新一次 React-Admin 列表数据?
How to refresh the React-Admin list data every X seconds?
cache documentation 提到我可以向数据提供者添加一个代理,以便我的响应被缓存 X 秒,而不是 React-Admin 在每次页面更改时刷新它们。但是,对于我的用例(股票交易应用程序),我想每 1 秒从我的 API 中为我的列表视图获取新数据。我原本希望通过使用上述缓存方法来做到这一点,但看起来如果用户在页面上时缓存过期,页面将不会自动刷新。
如何让我的 React-Admin 列表视图每 X 秒刷新一次,或者在缓存到期时自动刷新?
要定期更新列表视图,您可以使用:来自 React-Admin 的 useRefresh()
和来自此处的 useRecursiveTimeout()
:
https://www.aaron-powell.com/posts/2019-09-23-recursive-settimeout-with-react-hooks/
import React, { useEffect, useRef } from 'react';
import { List, useRefresh } from 'react-admin';
function useRecursiveTimeout(callback, delay) {
const savedCallback = useRef(callback)
useEffect(() => {
savedCallback.current = callback
}, [callback])
useEffect(() => {
let id
function tick() {
const ret = savedCallback.current()
if (ret instanceof Promise) {
ret.then(() => {
if (delay !== null) {
id = setTimeout(tick, delay)
}
})
} else {
if (delay !== null) {
id = setTimeout(tick, delay)
}
}
}
if (delay !== null) {
id = setTimeout(tick, delay)
return () => id && clearTimeout(id)
}
}, [delay])
}
const MyList = (props) => {
const refresh = useRefresh()
useRecursiveTimeout(() => refresh(), 1000)
return (
<List>
...
</List>
)
}
使用 React Admin v.4+ List 组件使用 react-query 而不是 Redux,您可以像那样传递 queryOptions
<List
queryOptions={{ refetchInterval: 1000 }}
/>
cache documentation 提到我可以向数据提供者添加一个代理,以便我的响应被缓存 X 秒,而不是 React-Admin 在每次页面更改时刷新它们。但是,对于我的用例(股票交易应用程序),我想每 1 秒从我的 API 中为我的列表视图获取新数据。我原本希望通过使用上述缓存方法来做到这一点,但看起来如果用户在页面上时缓存过期,页面将不会自动刷新。
如何让我的 React-Admin 列表视图每 X 秒刷新一次,或者在缓存到期时自动刷新?
要定期更新列表视图,您可以使用:来自 React-Admin 的 useRefresh()
和来自此处的 useRecursiveTimeout()
:
https://www.aaron-powell.com/posts/2019-09-23-recursive-settimeout-with-react-hooks/
import React, { useEffect, useRef } from 'react';
import { List, useRefresh } from 'react-admin';
function useRecursiveTimeout(callback, delay) {
const savedCallback = useRef(callback)
useEffect(() => {
savedCallback.current = callback
}, [callback])
useEffect(() => {
let id
function tick() {
const ret = savedCallback.current()
if (ret instanceof Promise) {
ret.then(() => {
if (delay !== null) {
id = setTimeout(tick, delay)
}
})
} else {
if (delay !== null) {
id = setTimeout(tick, delay)
}
}
}
if (delay !== null) {
id = setTimeout(tick, delay)
return () => id && clearTimeout(id)
}
}, [delay])
}
const MyList = (props) => {
const refresh = useRefresh()
useRecursiveTimeout(() => refresh(), 1000)
return (
<List>
...
</List>
)
}
使用 React Admin v.4+ List 组件使用 react-query 而不是 Redux,您可以像那样传递 queryOptions
<List
queryOptions={{ refetchInterval: 1000 }}
/>