score:1

Accepted answer

you're calling async method unlimited time! you need to call it once via useeffect just when component rendered for first time:

import parser from "rss-parser"; 
import react, { useeffect } from "react";

function episode() {
  const parser = new parser();
  const url1 = "https://anchor.fm/s/75abc654/podcast/rss";
  const [data, setdata] = react.usestate({});

  useeffect(() => {
    (async () => {
      let data = await parser.parseurl(url1);
      console.log(data);
      setdata(data);
    })();
  }, []);

  return (
    <>
      {data.items?.map((item, index) => (
        <h1>{item.title}</h1>
      ))}
    </>
  );
}
export default function app() {
  return <episode />;
}

edit nervous-pasteur-z6xu9

score:0

just replace your async function with a useeffect hook like this

useeffect(() => {
  async function fetchmyapi() {
    let data = await parser.parseurl(url1);
    setdata(data);
    // console.log(data.title)
    // data.items.foreach((item) => {
    // console.log(item.title)
    //console.log(item.pubdate.slice(5, 17))
    //console.log(item.enclosure.url)
    // console.log(item.itunes.image)
  }
  fetchmyapi();
}, []);

this will be executed once every time when your component is loaded on screen

also change the data.item.map to

{data.items?.map((item, index) => {
    return <h1>{item.title}</h1>;
 })}

else it will throw error on first render


Related Query

More Query from same tag