meta data for this page
  •  

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
ixc2024:tech:wfrontend:criteria:greencode [2024/05/22 14:49] alestaixc2024:tech:wfrontend:criteria:greencode [2024/05/22 15:38] (current) alesta
Line 1: Line 1:
 ==== Green Code Suggestions ==== ==== Green Code Suggestions ====
  
-Here are 20 best practices derived from the concepts in the "Green Code" book:+Here are ~20 best practices mostly derived from the concepts in the "Green Code" book:
  
 Reduce emissions: Reduce emissions:
   * **Minimize Data Traffic:** Reduce the amount of data transferred by optimizing images, compressing files, and utilizing efficient formats. This includes using formats like WebP for images and minifying CSS, JavaScript, and HTML files.   * **Minimize Data Traffic:** Reduce the amount of data transferred by optimizing images, compressing files, and utilizing efficient formats. This includes using formats like WebP for images and minifying CSS, JavaScript, and HTML files.
   * **Implement Efficient Caching:** Use browser caching to store static resources locally on the user's device. This reduces the need for repeated downloads.   * **Implement Efficient Caching:** Use browser caching to store static resources locally on the user's device. This reduces the need for repeated downloads.
 +  * **Lazy Loading:** Implement lazy loading for images and videos to ensure that they are only loaded when they enter the viewport. This reduces initial load times and data usage.
 +
 +
   * **Optimize Images and Videos:** Compress images and videos using tools like ImageOptim or HandBrake. Serve images in next-gen formats like WebP and videos in optimized formats like MP4.   * **Optimize Images and Videos:** Compress images and videos using tools like ImageOptim or HandBrake. Serve images in next-gen formats like WebP and videos in optimized formats like MP4.
   * **Use SVGs:** Where appropriate, use SVGs instead of raster images. SVGs are scalable and often smaller in size compared to bitmap images, leading to faster load times and less data transfer.   * **Use SVGs:** Where appropriate, use SVGs instead of raster images. SVGs are scalable and often smaller in size compared to bitmap images, leading to faster load times and less data transfer.
   * **Optimize Forms and User Inputs:** Reduce the size of user-uploaded images and videos by cropping and compressing them before upload. Implement client-side validation to reduce unnecessary server requests.   * **Optimize Forms and User Inputs:** Reduce the size of user-uploaded images and videos by cropping and compressing them before upload. Implement client-side validation to reduce unnecessary server requests.
-  * **Lazy Loading:** Implement lazy loading for images and videos to ensure that they are only loaded when they enter the viewport. This reduces initial load times and data usage.+ 
   *   **Implement Dark Mode:** Offer a dark mode option for OLED screens, which can save battery life for users. Ensure that dark mode is implemented efficiently without duplicating resources.   *   **Implement Dark Mode:** Offer a dark mode option for OLED screens, which can save battery life for users. Ensure that dark mode is implemented efficiently without duplicating resources.
 +
 +
   * **Efficient Font Loading:** Use only the necessary font weights and styles. Consider using system fonts to reduce the need for external font loading. When using web fonts, ensure they are loaded asynchronously and consider subsetting fonts to include only the characters needed.   * **Efficient Font Loading:** Use only the necessary font weights and styles. Consider using system fonts to reduce the need for external font loading. When using web fonts, ensure they are loaded asynchronously and consider subsetting fonts to include only the characters needed.
   * **Efficient Animations:** Use CSS animations instead of JavaScript for better performance and lower energy consumption. Avoid heavy animations that can drain device battery and processing power.   * **Efficient Animations:** Use CSS animations instead of JavaScript for better performance and lower energy consumption. Avoid heavy animations that can drain device battery and processing power.
 +
 +
   * **Reduce HTTP Requests:** Combine files where possible (e.g., CSS sprites, combined JavaScript files) to minimize the number of HTTP requests required to load a page.   * **Reduce HTTP Requests:** Combine files where possible (e.g., CSS sprites, combined JavaScript files) to minimize the number of HTTP requests required to load a page.
-  * **Use Content Delivery Networks (CDNs):** Utilize CDNs to serve static resources from locations closer to the user, reducing latency and improving load times. 
   * **Energy Efficient Content** Design the content to be as energy efficient as possible, while still taking care of it staying informative and valuable to the user.   * **Energy Efficient Content** Design the content to be as energy efficient as possible, while still taking care of it staying informative and valuable to the user.
-  * **Static Site Generation:** Consider using static site generators for websites that do not require dynamic content. This can significantly reduce server load and improve performance. 
-  * **Progressive Web Apps (PWAs):** Develop your site as a PWA to take advantage of offline capabilities and background syncing, reducing the need for constant data transfer. 
   * **Monitor and Optimize Performance:** Regularly monitor your website's performance (using Google Lighthouse). Continuously optimize based on insights to ensure your site remains efficient.   * **Monitor and Optimize Performance:** Regularly monitor your website's performance (using Google Lighthouse). Continuously optimize based on insights to ensure your site remains efficient.
  
Line 32: Line 36:
  
 Finally: Finally:
-  * **Educate and Collaborate:** Ensure that all team members are aware of and implement these sustainable practices. Collaboration and continuous education can help maintain a focus on sustainability throughout the development process.+  * **Holistic approach:** Understand both the business logic behind the solution that you are implementing and the user's experience or expectations of your application. Try to solve these potentially conflicting requirements efficiently.