
Responsive Time Tracking Dashboard with Dynamic JSON Data
Design comparison
Solution retrospective
I'm really proud of learning how to use the fetch() API in JavaScript for this project. It was my first time working with dynamic data fetching, and understanding how to handle JSON data and update the DOM based on user interactions was a huge win for me.
Along the way, I also practiced a lot with JavaScript conditionals, particularly for handling singular and plural units (like displaying "1hr" vs. "2hrs"). It was a small detail, but getting it right felt great because it made the data display feel more polished.
If I were to do the project again, I’d focus more on enhancing the user experience, like adding an active state to the buttons to give clearer feedback on which timeframe is currently selected. I'd also explore better ways to handle errors and possibly look into more scalable methods for updating the DOM.
What challenges did you encounter, and how did you overcome them?One of the main challenges I faced was learning how to properly use the fetch() API to load and display data dynamically from a JSON file. Initially, I struggled with understanding how to handle asynchronous operations and how to correctly structure the .then() promises to ensure the data was processed and displayed at the right time. I overcame this by breaking down the process step by step, reading documentation, and experimenting with different approaches until I understood how the data was flowing through my code.
What specific areas of your project would you like help with?I'd love some feedback on how I handled the fetch() API and data manipulation in JavaScript. This was my first time dynamically loading JSON data and updating the DOM, so I'm curious if there are more efficient or cleaner ways I could have structured my code.
Community feedback
- @DacardonacPosted 7 days ago
Hi Jayco, I hope things are going well for you 😊. I saw your project and I'm happy with it. Overall, everything looks good, and you did an excellent job. Congratulations 🎉. I want to give you feedback on some specific points or issues I've noticed, and I hope they'll help you improve on future projects.
-
Meta tags to improve SEO: If your project needs meta tags, which are very important for improving SEO and ranking better in browsers, you can read more about this at this link 🔎**[Metadata for SEO] (https://www.one.com/en/online-marketing/metadata-for-seo)**
-
Accessibility (a11y): Accessibility is essential since we need to consider all the potential users who will use our app or website, and we must be inclusive of each of them. In this case, I noticed that your website needs a bit more color contrast, which makes it difficult for people with limited vision to see 👁️. You should also include the ´alt´ attribute to describe your images and ´aria-label´ to describe your buttons, divs, etc., all so that a screen reader 💻 can read it to a visually impaired user.
-
Performance: You can improve the performance of your projects by minimizing file and image sizes ⬇️ and using more modern, higher-performance file extensions such as ´.webp´ for images, and ´.svg´ or ´.ico´ for icons or illustrations 🖼️.
I think this is all I noticed where you can improve Jayco. I hope my comment is very helpful and continue doing an excellent job 🙌. I congratulate you again and I hope you are very well 😊.
0 -
Please log in to post a comment
Log in with GitHubJoin our Discord community
Join thousands of Frontend Mentor community members taking the challenges, sharing resources, helping each other, and chatting about all things front-end!
Join our Discord