-
Notifications
You must be signed in to change notification settings - Fork 7
Lab 2
- Create a basic webpage
- Add a Leaflet map
- Add GeoJSON data to the map
- Create a GeoJSON online
This lab will walk you through the process of creating a static web page in HTML with some additional style elements using CSS. Then you will be tasked to add a map using the Leaflet JS library and host it using GitHub pages.
Note: I highly recommend checking out the Leaflet documentation. Looking at any documentation before choosing any software is important, because badly documented libraries can make tools difficult to use.
Start up VS Code and open your Assignments repo:
Remember to select the correct folder!
Make sure Explorer is open in the activity bar by clicking on it:
Click on Week_02
(1) and then the new file
button (2):
HTML is what makes up the house for websites to be able to talk to the server. Everything in HTML is surrounded by tags which look like this:
<tag> Look Ma'! I'm in a tag! </tag>
If we can only use tags, the web would be a pretty boring place. So in order to make each tag unique, we can add attributes to them. To do so, you add an attribute="some value"
For example, we can name a tag something:
<tag name="Albert"></tag>
Wow, that's my name tag!
In coding, boilerplate code is ready to use code that people can freely copy and use with no changes. Think of them as ready-to-eat microwave dinners.
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8"/>
<title></title>
</head>
<body>
</body>
</html>
Template code refers to sample code that can be copied and pasted, but requires modifications in order for it to work.
Here is our template code:
<!DOCTYPE html>
<html>
<head>
<title>Hello World with Leaflet</title>
<meta charset="utf-8" />
<link rel="shortcut icon" href="#">
<!-- I'd add some style if here if I had any -->
</head>
<body>
<header>
Hello World!
</header>
<div class="main">
<!-- hint: majority of your lab assignment can go here -->
</div>
<div id="footer">
Copyright(2021)
</div>
</body>
</html>
What do you observe in the code?
- How does this code differ from the boilerplate code?
- Why should everything be enclosed in the
html
tag?- Do empty spaces matter in HTML?
- What is a comment and how do you write one?
- Is there a difference between the
class
andid
attributes?
Let's fix our code so that it actually looks presentable. Look for the errors in the template code.
Save the file and name it index.html
and open it in Firefox.
Make sure you have the Live Server extension installed: https://marketplace.visualstudio.com/items?itemName=ritwickdey.LiveServer
Click on Go Live!
Your default browser should automatically pop-up, if it is not Firefox, you will need to copy and paste the link over.
Alternatively: Right click on your index.html
file and reveal in file explorer
. Then, double click on the file.
Let's add some Cascading Style Sheets (CSS) to visualize our page better.
Insert the following code in the <head>
right before the closing tag (i.e. </head>
):
<style>
html {
background-color: azure;
}
</style>
What happened to the page?
That's cool! But this way of using CSS, called inline CSS, can make your HTML file long and cumbersome. So it's usually better to have a separate file for CSS and bring that whole file in as a linked source.
Click the new folder button:
Highlight the style
folder by clicking on it:
Then click on the new file
button file:
Name the file style.css
:
Double click to open the new file. Then copy and paste the following CSS:
html, body {
padding: 5px;
}
body {
display: grid;
grid-template-rows: .1fr .30fr .60fr .05fr;
grid-template-columns: 1fr;
grid-template-areas: "header" "main" "map" "footer";
justify-content: center;
}
header {
grid-area: header;
display: grid;
grid-template-columns: .2fr .6fr .2fr;
justify-content: center;
}
.main {
display: grid;
grid-area: main;
background-color: aqua;
}
#map {
grid-area: map;
height: 40vh;
}
#footer {
grid-area: footer;
}
Remember to save the style.css
!
Next go back to the index.html
file and replace your entire <style> </style>
content and tags with this code:
<link rel="stylesheet" href="style/style.css">
What this code does is that it tells the HTML file to use all of the css in the href
attribute.
We will go into CSS in more detail later, but what you need to know is that CSS has selectors
which are then followed by the styles in { }
.
JavaScript makes sure our page knows how to function and react. There are different frameworks for JavaScript, like React.js and vue.js, but this class will be focusing on vanilla JavaScript with ES7+ standards. All JavaScript must be contained within a script tag. In our <head>
tag, let's add a <script></script>
tag.
Sometimes it also becomes important to put JavaScript in the footer tag, why is that? Sometimes you need JavaScript functions to run after the body loads, so putting <script>
after the </body>
becomes necessary. This will be relevant when we bring in Leaflet.js.
Remember how we had field types in QGIS? Like, double, float and string? In programming languages we call those "types." With JavaScript, variables are automatically assigned types based on their declaration. We'll discuss more next week, but is a quick introducing the concept of variables and declarations.
This is an example of a declaration:
var day = 8;
var name = "Albert";
Here day
is a number type and name
is a string type. Each type has certain properties with them, for example you can add numbers together using something like day + day
, but you adding strings will simply concatenate and not total them.
Important note, that with JavaScript ES7, we no longer use var
, but instead let
and const
to declare variables. They get declared in the same way:
let day = 8;
const name = "Albert";
What is the difference?
-
let
declaration allows a variable to change -
const
means a variable is constant and will never change. -
var
can be both changed and never changed depending on where it was declared! VERY PROBLEMATIC!
Because var
can be changing (mutable) and unchanging at the same time, so it was broken off into two variable types, let
and const
.
So, bye bye var
and LET
us welcome our new CONST
variables to the programming world.
To recap: NEVER USE var
unless you have to code for old browsers.
By itself, our script tag does nothing. So, one VERY important JavaScript method that we should familarize ourself with is console.log()
, because it allows us to test our code without things showing up in the webpage.
Add the following script:
<script>
console.log('Hello Asian Am 191! :)');
</script>
Actually, you are about to unlock your full web developer potential!
In Firefox, right click anywhere on the page and the click Inspect Element
:
This opens the Developer Toolbar
!! You can find it by going to the Menu and going to Web Developer
and then Web Developer Tools
.
Click on the Console button:
Yay! Our message is there!
Similar to the CSS files, we can move the JavaScript file into its own folder to avoid cluttering the HTML file. Importing libraries is the main way we level up our webpage.
BUT!!! Instead of <link>
we use the <script>
tag:
<script src="YOUR_SCRIPT_NAME.js"></script>
The src
attribute is location of your file.
- Create a new folder called
js
- Add our script in there
- Get our message to show up in the console
OK, why did we do ALL of that? Well, when we use Leaflet, we actually need to bring in Leaflet's external CSS and JavaScript files!
So, in our header, let's add the following:
<!-- Leaflet's css-->
<link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/leaflet.css" />
<!-- Leaflet's JavaScript-->
<script src="https://unpkg.com/[email protected]/dist/leaflet.js"></script>
Now, let's go ahead and add a container for our map.
After <div id="main"></div>
add a new <div></div>
tag, and give it an ID attribute of "map":
<div id="map"></div>
With our container ready to go, open up the JavaScript file again and add the following Leaflet code template:
// JavaScript const variable declaration
const map = L.map('map').setView([34.0709, -118.444], 15);
// Leaflet tile layer, i.e. the base map
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);
//JavaScript let variable declaration to create a marker
let marker = L.marker([34.0709, -118.444]).addTo(map)
.bindPopup('Math Sciences 4328 aka the Technology Sandbox<br> is the lab where I work in ')
.openPopup();
-
Looking at the code above a little bit, we can see some latitude/longitude pairs. Copy the marker code add more markers of your choosing. Note: Be sure give the marker variable a new name, like
marker2
. -
To find latitude/longitude of coordinates, please use this website:
-
Optional: Not happy with the basemap? See if you can switch the basemap out by visiting here:
Save and commit your project to GitHub.
Then visit your repository link on GitHub.
Click on Settings:
Scroll down to "GitHub pages" and under source click here:
Click on the "main" branch:
Choose "root":
Click on Save:
Copy the link and put it in your readme.md
file in the week 2
folder.
You can see the html
file if you go to
https://YOUR_GITHUB_ACCOUNT.github.io/21S-ASIAAM-191A-Assignments/Week_02/index.html
Copy lab1.geojson
from last week into this lab's folder. If you changed the name of it, please use your filename to follow along or rename the file to lab1.geojson.
We will use the JavaScript Fetch API to get our geojson file and then add it to our map. In JavaScript whenever you see a .
after a parenthesis, it means you are chaining a command to follow it. In this case we are chaining a then
method. In the then
method we will have a
fetch("js/lab1.geojson")
.then(response => {
return response.json();
})
.then(data =>{
// Basic Leaflet method to add GeoJSON data
L.geoJSON(data).addTo(map)
});
The map should now have a blue tint over it and you cannot interact with it. Not really useful.
Add the basic Leaflet method for a geojson:
// the leaflet method for adding a geojson
L.geoJSON(data, {
style: function (feature) {
return {color: 'red'};
}
}).bindPopup(function (layer) {
return layer.feature.properties.name;
}).addTo(map);
The completed fetch
code should look like this:
fetch("js/lab1.geojson")
.then(response => {
return response.json();
})
.then(data =>{
// Basic Leaflet method to add GeoJSON data
// the leaflet method for adding a geojson
L.geoJSON(data, {
style: function (feature) {
return {color: 'red'};
}
}).bindPopup(function (layer) {
return layer.feature.properties.name;
}).addTo(map);
});
Notice now that when you click on the map, the name of the counties show up.
The boundary that we added from last week doesn't really seem to add much. Let's put to practice what web development and GIS can do for power.
Head over to this website: http://www.geojson.io/
Click on the marker tool:
Click on a location of interest to you:
Add a data column:
Call it place and click "OK":
Click inside the place column
Type in a description for the place, in this case I called it "home".
Zoom out:
Click the edit button:
Click the move the marker to the adjust the location:
Save your edit:
Repeat these steps until you have a few points.
Add another column called "color", to put some color to your map later.
Save your file:
Click geoJSON:
Download the file to your computer:
Copy the file into your project folder:
Change lab1.geojson
to map.geojson
(the name of the file we downloaded) in the fetch
code:
fetch("js/map.geojson")
.then(response => {
return response.json()
})
.then(data =>{
// Basic Leaflet method to add GeoJSON data
L.geoJSON(data, myLayerOptions)
.bindPopup(function (layer) {
return layer.feature.properties.place;
}).addTo(map);
})
Bam! It updated!
Utilize our color property:
function customMarker (feature, latlng) {
return L.circleMarker(latlng, { color: feature.properties.color })
}
// create an options object
let myLayerOptions = {
pointToLayer: customMarker
}
Now think about how empowering it was for you to be able to add data to the map yourselves. Whether you were clicking random spots or trying to find your old favorite places to visit, the ability to mark things is a reclaiming of mapping for yourself. This sense of staking a claim is what I mean when I refer to "empowering community voices".
index.html
<!DOCTYPE html>
<html>
<head>
<title>Hello World with Leaflet</title>
<meta charset="utf-8" />
<link rel="shortcut icon" href="#">
<!-- I'd add some style if here if I had any -->
<link rel="stylesheet" href="style/style.css">
<script>
console.log('Hello Asian Am 191! :)')
</script>
<!-- Leaflet's css-->
<link rel="stylesheet" href="https://unpkg.com/[email protected]/dist/leaflet.css" />
<!-- Leaflet's JavaScript-->
<script src="https://unpkg.com/[email protected]/dist/leaflet.js"></script>
<script src="./js/lab1.js"></script>
</head>
<body>
<header>
My Map
</header>
<div class="main">
</div>
<div id="map"></div>
<div id="footer">
Copyright(2021)
</div>
</body>
<script src="./js/init.js"></script>
</html>
js/init.js
const map = L.map('map').setView([34.0709, -118.444], 5);
// Leaflet tile layer, i.e. the base map
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© <a href="https://www.openstreetmap.org/copyright">OpenStreetMap</a> contributors'
}).addTo(map);
//JavaScript let variable declaration to create a marker
let marker = L.marker([34.0709, -118.444]).addTo(map)
.bindPopup('Math Sciences 4328 aka the Technology Sandbox<br> is the lab where I work in ')
// .openPopup();
fetch("js/map.geojson")
.then(response => {
return response.json();
})
.then(data =>{
// Basic Leaflet method to add GeoJSON data
// the leaflet method for adding a geojson
L.geoJSON(data, {
style: function (feature) {
return {color: 'red'};
}
}).bindPopup(function (layer) {
return layer.feature.properties.place;
}).addTo(map);
});
style/style.css
html, body {
padding: 5px;
}
body {
display: grid;
grid-template-rows: .1fr .30fr .60fr .05fr;
grid-template-columns: 1fr;
grid-template-areas: "header" "main" "map" "footer";
justify-content: center;
}
header {
grid-area: header;
display: grid;
grid-template-columns: .2fr .6fr .2fr;
justify-content: center;
}
.main {
display: grid;
grid-area: main;
background-color: aqua;
}
#map {
grid-area: map;
height: 40vh;
}
#footer {
grid-area: footer;
}
Syllabus | Class Recordings | Class Dictionary | Extra Resources
Need some help? Visit office hours or post in the Help Desk
Home
Week 1
- Materials
- Assignments
Week 2
- Materials
- Assignments
Week 3
- Materials
- Assignments
- Thinking Cap #2
- Lab #2
- Group Assignment #1
- Reading
Week 4
Week 5
- Assignments
- Extra Credit
Week 6
- Assignments
- Extra Credit
Week 7
- Assignments
Week 8
- Assignments
Week 9
- Assignments
Week 10
- Assignments
Finals Week
- Assignments