| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | --- | 
					
						
							|  |  |  |  | id: 587d7fa8367417b2b2512bcd | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | title: 为集合中的每个数据点创建一个数据条 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | challengeType: 6 | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | forumTopicId: 301482 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  |  | dashedName: create-a-bar-for-each-data-point-in-the-set | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | --- | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | # --description--
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 上个挑战在 `svg` 中只添加了一个矩形来表示数据条。 接下来你将结合到目前为止所学的关于 `data()`、`enter()` 和 SVG 图形的知识,为 `dataset` 中的每一个数据点创建并且添加一个矩形。 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 之前的挑战展示了如何为 `dataset` 中的每个对象创建并添加一个 `div`: | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | ```js | 
					
						
							|  |  |  |  | d3.select("body").selectAll("div") | 
					
						
							|  |  |  |  |   .data(dataset) | 
					
						
							|  |  |  |  |   .enter() | 
					
						
							|  |  |  |  |   .append("div") | 
					
						
							|  |  |  |  | ``` | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 操作 `rect` 元素和 `divs` 有一些不同。 `rects` 必须添加在 `svg` 元素内,而不能直接添加在 `body` 内。 同时,你需要告诉 D3 将 `rect` 放在 `svg` 区域的哪个位置。 条形的放置会在下一个挑战中讲到。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | # --instructions--
 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 用 `data()`、`enter()`、`append()` 方法为 `dataset` 中的每一个对象创建并添加一个 `rect` 。 每个数据条都将直接显示在上一个数据条的上面,这一点将在下一个挑战中实现。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | # --hints--
 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 应该包含 9 个 `rect` 元素。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | ```js | 
					
						
							|  |  |  |  | assert($('rect').length == 9); | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | ``` | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 应该使用 `data()` 方法。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | ```js | 
					
						
							|  |  |  |  | assert(code.match(/\.data/g)); | 
					
						
							|  |  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 应该使用 `enter()` 方法。 | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | ```js | 
					
						
							|  |  |  |  | assert(code.match(/\.enter/g)); | 
					
						
							|  |  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-09 08:51:59 -07:00
										 |  |  |  | 应该使用 `append()` 方法。 | 
					
						
							| 
									
										
										
										
											2020-09-18 00:13:05 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | ```js | 
					
						
							|  |  |  |  | assert(code.match(/\.append/g)); | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-08-13 17:24:35 +02:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  |  | # --seed--
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ## --seed-contents--
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | ```html | 
					
						
							|  |  |  |  | <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> | 
					
						
							|  |  |  |  | ``` | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  |  | # --solutions--
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  |  | ```html | 
					
						
							|  |  |  |  | <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") | 
					
						
							|  |  |  |  |        .data(dataset) | 
					
						
							|  |  |  |  |        .enter() | 
					
						
							|  |  |  |  |        .append("rect") | 
					
						
							|  |  |  |  |        .attr("x", 0) | 
					
						
							|  |  |  |  |        .attr("y", 0) | 
					
						
							|  |  |  |  |        .attr("width", 25) | 
					
						
							|  |  |  |  |        .attr("height", 100); | 
					
						
							|  |  |  |  |   </script> | 
					
						
							|  |  |  |  | </body> | 
					
						
							|  |  |  |  | ``` |