2.7 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	
			2.7 KiB
		
	
	
	
	
	
	
	
id, title, challengeType
| id | title | challengeType | 
|---|---|---|
| 587d7fa8367417b2b2512bcd | Create a Bar for Each Data Point in the Set | 6 | 
Description
svg element to represent a bar. Here, you'll combine what you've learned so far about data(), enter(), and SVG shapes to create and append a rectangle for each data point in dataset.
A previous challenge showed the format for how to create and append a div for each item in dataset:
d3.select("body").selectAll("div")There are a few differences working with
.data(dataset)
.enter()
.append("div")
rect elements instead of divs. The rects must be appended to an svg element, not directly to the body. Also, you need to tell D3 where to place each rect within the svg area. The bar placement will be covered in the next challenge.
Instructions
data(), enter(), and append() methods to create and append a rect for each item in dataset. The bars should display all on top of each other, this will be fixed in the next challenge.
Tests
tests:
  - text: Your document should have 9 <code>rect</code> elements.
    testString: assert($('rect').length == 9, 'Your document should have 9 <code>rect</code> elements.');
  - text: Your code should use the <code>data()</code> method.
    testString: assert(code.match(/\.data/g), 'Your code should use the <code>data()</code> method.');
  - text: Your code should use the <code>enter()</code> method.
    testString: assert(code.match(/\.enter/g), 'Your code should use the <code>enter()</code> method.');
  - text: Your code should use the <code>append()</code> method.
    testString: assert(code.match(/\.append/g), 'Your code should use the <code>append()</code> method.');
Challenge Seed
<body>
  <script>
    const dataset = [12, 31, 22, 17, 25, 18, 29, 14, 9];
    const w = 500;
    const h = 100;
    const svg = d3.select("body")
                  .append("svg")
                  .attr("width", w)
                  .attr("height", h);
    svg.selectAll("rect")
       // Add your code below this line
       // Add your code above this line
       .attr("x", 0)
       .attr("y", 0)
       .attr("width", 25)
       .attr("height", 100);
  </script>
</body>
Solution
// solution required