In this tutorial, you will use CO2.js in the browser to calculate the CO2 emissions of transferring 1 gigabyte (GB) or data.
You can follow along with this tutorial in your local development environment, or by using the button below to launch the project in Gitpod.
It is also worth noting that currently CO2.js uses the Sustainable Web Design Model as the default when calculating carbon emissions.a Check out the Methodologies for calculating website carbon page to learn more about both models.
In the root of your project, create an index.html file. Open this file in your code editor of choice. We will write the rest of this tutorial inside this index.html file.
Here's some boilerplate code to get started with. Copy this into the index.html file you just created.
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>My CO2.js calculator</title>
    <script type="module">
      <!-- Our code will go here -->
    </script>
  </head>
  <body>
    <h1>The carbon emissions of 1 gigabyte</h1>
    <p>
      Sending a gigabyte, had a carbon footprint of
      <span id="result">???????</span> grams of CO2
    </p>
  </body>
</html>So that we can get to writing code sooner, we will use Skypack in this tutorial to download the CO2.js library.
In the index.html file you just created, add the following line inside the <script> block in the head of the page.
import tgwf from "https://cdn.skypack.dev/@tgwf/co2";CO2.js includes a perByte() function. This function accepts two variables:
number - The bytes you want to calculate CO2 for.boolean - Whether the bytes are transferred from a green host. By default, this value is false.Adding the code below to the <script> block allows us to calculate the carbon emissions of a gigabyte, transferred from a regular (not green) host. Be sure to add this code after the import statement.
const emissions = new tgwf.co2();
const bytesSent = 1000 * 1000 * 1000; // 1GB expressed in bytes
const greenHost = false; // Is the data transferred from a green host?
let estimatedCO2 = emissions.perByte(bytesSent, greenHost).toFixed(3); // We use toFixed(3) here to set the result to 3 decimal places.
document.getElementById("result").innerHTML = estimatedCO2;In the code above, you are:
co2.js library.perByte function, which returns a carbon estimate.When you're done, the <script> block should look like this:
<script type="module">
  import tgwf from "https://cdn.skypack.dev/@tgwf/co2";
  const emissions = new tgwf.co2();
  const bytesSent = 1000 * 1000 * 1000; // 1GB expressed in bytes
  const greenHost = false; // Is the data transferred from a green host?
  let estimatedCO2 = emissions.perByte(bytesSent, greenHost).toFixed(3);
  document.getElementById("result").innerHTML = estimatedCO2;
</script>To find out how much carbon 1GB of data produces, open the index.html page in a web browser.
If you're following along in GitPod, you can run python -m http.server 8000 to start a local server.
You now know the carbon impact of a gigabyte, and can display it on a web page.
From here you can:
bytesSent variable.greenHost variable to true and see how green hosting effects carbon emissions.