admin管理员组文章数量:1122846
Working on a Astro 5 (beta10) application.
The astro is configured with "output": "server".
I have a .tsx component in which I want to fetch data from an API. (Strapi, a CMS).
Since a sensitive API token is used to fetch the data I need it to happen on the server. So I put astro in "output": "server" mode. But the code is now never called. And when I put client:load on the component it execute on the browser which does not have access to the API Token.
My understanding would be to fetch the data from the parent .astro component and pass it as a props to the .tsx component.
Is this the right understanding or is there a 'good' way to fetch the data from the server inside the .tsx component ?
Below the code of the .tsx component :
const Navbar: React.FC = () => {
const [navbarTabs, setNavbarTabs] = useState<NavbarTab[]>([]);
const fetchNavbarTabs = async () => {
const tabs = await strapiFetch({
endpoint: "navbar-tabs",
wrappedByKey: "data",
});
setNavbarTabs(tabs);
};
useEffect(() => {
fetchNavbarTabs();
}, []);
useEffect(() => {
console.log(navbarTabs.length);
}, [navbarTabs]);
return (
<></>
);
};
export default Navbar;
Working on a Astro 5 (beta10) application.
The astro is configured with "output": "server".
I have a .tsx component in which I want to fetch data from an API. (Strapi, a CMS).
Since a sensitive API token is used to fetch the data I need it to happen on the server. So I put astro in "output": "server" mode. But the code is now never called. And when I put client:load on the component it execute on the browser which does not have access to the API Token.
My understanding would be to fetch the data from the parent .astro component and pass it as a props to the .tsx component.
Is this the right understanding or is there a 'good' way to fetch the data from the server inside the .tsx component ?
Below the code of the .tsx component :
const Navbar: React.FC = () => {
const [navbarTabs, setNavbarTabs] = useState<NavbarTab[]>([]);
const fetchNavbarTabs = async () => {
const tabs = await strapiFetch({
endpoint: "navbar-tabs",
wrappedByKey: "data",
});
setNavbarTabs(tabs);
};
useEffect(() => {
fetchNavbarTabs();
}, []);
useEffect(() => {
console.log(navbarTabs.length);
}, [navbarTabs]);
return (
<></>
);
};
export default Navbar;
Share
Improve this question
edited Nov 25, 2024 at 7:31
VLAZ
28.8k9 gold badges62 silver badges82 bronze badges
asked Nov 22, 2024 at 21:17
NeitoFRNeitoFR
8071 gold badge12 silver badges24 bronze badges
1 Answer
Reset to default 1The reason your example doesn't work is because useEffect
are never executed on the server (that's how React works, nothing Astro-specific). There are special data-fetching libs for React (like React Query), but if you're using Astro, I would just do as you suggested and fetch the data in the .astro component and pass it into the jsx as props.
P.S. This is unrelated to the data fetching, but note that "output": "server"
mode means you're not building a static site anymore. This may or may not be what you want (you could also set up Netlify or similar to retrigger a static build whenever the content in your CMS changes. But that will take a minute or two, so perhaps you're right that you want output: server
, then it will fetch from the CMS every time somebody looks at your website.) See https://docs.astro.build/en/basics/rendering-modes/
本文标签: reactjsHow can I fetch data from server inside a tsx componentStack Overflow
版权声明:本文标题:reactjs - How can I fetch data from server inside a .tsx component? - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736300814a1930954.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论