• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

116
Views
How to give class to DOMelements by using querySelectorAll in React useLayoutEffect?

My Apps has Calender(Using FullCalender).
I want to give class to elements by using querySelectorAll before first rendering.
So, I use React Hooks useLayoutEffect. But It doesn't work.
Please tell me how to solve this probrem.

let availableDateList = [];

const Calender = () => {
  const setAvailableDateListClass = () => {
    availableDateList.map((availableDate) =>
      document
        .querySelectorAll('[data-date="' + availableDate + '"]')
        .forEach((date) => date.classList.add("available"))
    );
  };
  useLayoutEffect(() => {
    const fetchData = async () => {
      const res = await axios(API_URL);
      let data = await res.data;
      data.map((e) => availableDateList.push(e.date));
    };
    fetchData();
    setAvailableDateListClass();
  }, []);

  const calenderRenderHandling = (e) => {
    setAvailableDateListClass();
  };


  return (
    <>
      <FullCalendar
        plugins={[dayGridPlugin, interactionPlugin]}
        initialView="dayGridMonth"
        events={callenderEvents}
        eventOverlap={false}
        datesSet={calenderRenderHandling}
      />
    </>
  );
};
export default Calender;
"axios": "^0.27.2",
"react": "^18.1.0",
"react-dom": "^18.1.0",
 "react-scripts": "^5.0.1",
 "@fullcalendar/daygrid": "^5.11.0",
 "@fullcalendar/interaction": "^5.11.0",
 "@fullcalendar/react": "^5.11.1",
about 3 years ago · Juan Pablo Isaza
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error