You'll be making the same bar plot in three different ways. Each time, you will end up something that looks like this:
This is an exercise to practice basic HTML, SVG, and CSS syntax. It is also designed to demonstrate that something that looks like a chart on a website is actually just a collection of simple HTML elements.
You'll want to open the file barHtml.html
and perform the following steps (instructions are also in the file):
- Make a container
<div>
in which you'll render your content - Create a
<p>
element in which you write "My Bar Chart" - Make a container
<svg>
element in which you'll place your rectangles
- Set your svg's
width
to 300, andheight
to400
-
Put 3
<rect>
elements inside of your<svg>
, setting the properties for each one:x
: How far to move the rectangle in thex
direction (right). Should be0
for all rectangles.y
: How for to move the rect in they
direction (down from the top). Should be10
,40
70
width
: How far to draw the rectangle to the right. Should be100
,200
,300
height
: The vertical height of each rectangle. Should be20
for all rectangles
-
In the
<style>
section, setrect
elements to have a "fill" of "purple" (or whatever color you like)
See a finished example here.
This is an exercise to practice manipulating the DOM with D3.
You'll want to open the file barD3.html
and perform the following steps (instructions are also in the file). All steps will be completed using d3.js, and should be completed in the <script>
section at the bottom of the file.
- Select your
body
and append adiv
element in which you'll render your content. To do this, you'll use thed3.select()
method, and then the.append()
method to append your element to your selection. - Append a new
p
element to thediv
you just created, and use the.text()
method to set the text to "My Bar Chart" - Append a container
svg
to yourdiv
element in which you'll place your rectangles
- Set your svg's
width
to 300, andheight
to400
- Append 3
rect
elements inside of your<svg>
(one at a time), setting the properties for each one. We'll improve on this process later:x
: How far to move the rectangle in thex
direction (right). Should be0
for all rectangles.y
: How for to move the rect in they
direction (down from the top). Should be10
,40
70
width
: How far to draw the rectangle to the right. Should be100
,200
,300
height
: The vertical height of each rectangle. Should be20
for all rectangles
See a finished example here.
This is an exercise to practice manipulating the DOM D3 using the data-join.
You'll want to open the file barD3DataJoin.html
and perform the following steps (instructions are also in the file). All steps will be completed using d3.js, and should be completed in the <script>
section at the bottom of the file. Preliminary steps have been completed for you.
- Append 3
rect
elements inside of your<svg>
using the data join. To do this, you'll use the following syntax:
// Select all rects in the svg and bind your data to the selection
var rects = svg.selectAll('rect')
// Determine what's new to the screen using `.enter()` and for each new element, append a rectangle
// Then, use the data provided to set the desired attributes
rects.data(data)
.enter()
.append('rect')
.attr('x', 0)
.attr('height', 20)
.attr('y', function(d,i){return d.y}) // use y attribute to drive layout
.attr('width', function(d,i){return d.width}); // use width attribute to drive layout
- `x`: How far to move the rectangle in the `x` direction (right). Should be `0` for all rectangles.
- `y`: How for to move the rect in the `y` direction (down from the top). Should be `10`, `40` `70`
- `width`: How far to draw the rectangle to the right. Should be `100`,`200`, `300`
- `height`: The vertical height of each rectangle. Should be `20` for all rectangles
See a finished example here.