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 1byte model as the default when calculating carbon emissions. There is currently an open issue to update this to the more recent Sustainable Web Design methodology. 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.