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
Add a comment  | 

1 Answer 1

Reset to default 1

The 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