| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | --- | 
					
						
							|  |  |  | id: bad87fee1348bd9aedf08805 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | title: 使用元素选择器来设置元素的样式 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | challengeType: 0 | 
					
						
							| 
									
										
										
										
											2019-12-13 13:47:57 +08:00
										 |  |  | videoUrl: 'https://scrimba.com/c/cJKMBT2' | 
					
						
							|  |  |  | forumTopicId: 18349 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  | dashedName: use-css-selectors-to-style-elements | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | --- | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | # --description--
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 04:42:36 +00:00
										 |  |  | 在 CSS 中,页面样式的属性有几百个,你可以用来改变元素在页面上的外观。 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 04:42:36 +00:00
										 |  |  | 当你输入 `<h2 style="color: red;">CatPhotoApp</h2>`,就可以用行内 CSS 设置 `h2` 元素的样式。 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 04:42:36 +00:00
										 |  |  | 这是指定元素样式的一种方法,但有一个更好的方法来应用 CSS。 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-08 11:20:48 -08:00
										 |  |  | 在代码的顶部,创建一个 `style` 声明区域,如下方所示: | 
					
						
							| 
									
										
										
										
											2019-12-13 13:47:57 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```html | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 04:42:36 +00:00
										 |  |  | 在样式声明区域内,可以为所有 `h2` 元素创建一个 <dfn>CSS selector</dfn>。 如果想让所有 `h2` 元素在变成红色,可以添加下方的样式规则: | 
					
						
							| 
									
										
										
										
											2019-12-13 13:47:57 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```html | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   h2 { | 
					
						
							|  |  |  |     color: red; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-06 04:42:36 +00:00
										 |  |  | 请注意,每个元素的样式规则都应该有开始和结束大括号(`{` 和 `}`)。 还需要确保元素的样式定义在开始和结束样式标签之间。 你需要确保所有样式规则位于花括号之间,并且每条样式规则都以分号结束。 | 
					
						
							| 
									
										
										
										
											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-02-06 04:42:36 +00:00
										 |  |  | 请删除 `h2` 元素的行内样式,然后创建 `style` 样式声明区域, 最后添加 CSS 样式规则使所有 `h2` 元素变为蓝色。 | 
					
						
							| 
									
										
										
										
											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-02-06 04:42:36 +00:00
										 |  |  | 应删除 `h2` 元素的 `style` 样式。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert(!$('h2').attr('style')); | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-08 11:20:48 -08:00
										 |  |  | 应创建一个 `style` 样式声明区域。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert($('style') && $('style').length >= 1); | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-08 11:20:48 -08:00
										 |  |  | `h2` 元素颜色应为蓝色。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert($('h2').css('color') === 'rgb(0, 0, 255)'); | 
					
						
							|  |  |  | ``` | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-08 11:20:48 -08:00
										 |  |  | 确保 `h2` 选择器的内容被花括号所包围,样式规则应以分号结束。 | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | ```js | 
					
						
							|  |  |  | assert(code.match(/h2\s*\{\s*color\s*:.*;\s*\}/g)); | 
					
						
							| 
									
										
										
										
											2018-10-10 18:03:03 -04:00
										 |  |  | ``` | 
					
						
							| 
									
										
										
										
											2020-02-18 01:40:55 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-08 11:20:48 -08:00
										 |  |  | `style` 标签应符合语法,且应有一个结束标签。 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | ```js | 
					
						
							|  |  |  | assert( | 
					
						
							|  |  |  |   code.match(/<\/style>/g) && | 
					
						
							|  |  |  |     code.match(/<\/style>/g).length === | 
					
						
							|  |  |  |       ( | 
					
						
							|  |  |  |         code.match( | 
					
						
							|  |  |  |           /<style((\s)*((type|media|scoped|title|disabled)="[^"]*")?(\s)*)*>/g | 
					
						
							|  |  |  |         ) || [] | 
					
						
							|  |  |  |       ).length | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  | # --seed--
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ## --seed-contents--
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ```html | 
					
						
							|  |  |  | <h2 style="color: red;">CatPhotoApp</h2> | 
					
						
							|  |  |  | <main> | 
					
						
							|  |  |  |   <p>Click here to view more <a href="#">cat photos</a>.</p> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <a href="#"><img src="https://bit.ly/fcc-relaxing-cat" alt="A cute orange cat lying on its back."></a> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <div> | 
					
						
							|  |  |  |     <p>Things cats love:</p> | 
					
						
							|  |  |  |     <ul> | 
					
						
							|  |  |  |       <li>cat nip</li> | 
					
						
							|  |  |  |       <li>laser pointers</li> | 
					
						
							|  |  |  |       <li>lasagna</li> | 
					
						
							|  |  |  |     </ul> | 
					
						
							|  |  |  |     <p>Top 3 things cats hate:</p> | 
					
						
							|  |  |  |     <ol> | 
					
						
							|  |  |  |       <li>flea treatment</li> | 
					
						
							|  |  |  |       <li>thunder</li> | 
					
						
							|  |  |  |       <li>other cats</li> | 
					
						
							|  |  |  |     </ol> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <form action="https://freecatphotoapp.com/submit-cat-photo"> | 
					
						
							|  |  |  |     <label><input type="radio" name="indoor-outdoor" checked> Indoor</label> | 
					
						
							|  |  |  |     <label><input type="radio" name="indoor-outdoor"> Outdoor</label><br> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality" checked> Loving</label> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality"> Lazy</label> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality"> Energetic</label><br> | 
					
						
							|  |  |  |     <input type="text" placeholder="cat photo URL" required> | 
					
						
							|  |  |  |     <button type="submit">Submit</button> | 
					
						
							|  |  |  |   </form> | 
					
						
							|  |  |  | </main> | 
					
						
							|  |  |  | ``` | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-12-16 00:37:30 -07:00
										 |  |  | # --solutions--
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 03:31:00 +01:00
										 |  |  | ```html | 
					
						
							|  |  |  | <style> | 
					
						
							|  |  |  |   h2 { | 
					
						
							|  |  |  |     color: blue; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | </style> | 
					
						
							|  |  |  | <h2>CatPhotoApp</h2> | 
					
						
							|  |  |  | <main> | 
					
						
							|  |  |  |   <p>Click here to view more <a href="#">cat photos</a>.</p> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <a href="#"><img src="https://bit.ly/fcc-relaxing-cat" alt="A cute orange cat lying on its back."></a> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <div> | 
					
						
							|  |  |  |     <p>Things cats love:</p> | 
					
						
							|  |  |  |     <ul> | 
					
						
							|  |  |  |       <li>cat nip</li> | 
					
						
							|  |  |  |       <li>laser pointers</li> | 
					
						
							|  |  |  |       <li>lasagna</li> | 
					
						
							|  |  |  |     </ul> | 
					
						
							|  |  |  |     <p>Top 3 things cats hate:</p> | 
					
						
							|  |  |  |     <ol> | 
					
						
							|  |  |  |       <li>flea treatment</li> | 
					
						
							|  |  |  |       <li>thunder</li> | 
					
						
							|  |  |  |       <li>other cats</li> | 
					
						
							|  |  |  |     </ol> | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <form action="https://freecatphotoapp.com/submit-cat-photo"> | 
					
						
							|  |  |  |     <label><input type="radio" name="indoor-outdoor" checked> Indoor</label> | 
					
						
							|  |  |  |     <label><input type="radio" name="indoor-outdoor"> Outdoor</label><br> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality" checked> Loving</label> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality"> Lazy</label> | 
					
						
							|  |  |  |     <label><input type="checkbox" name="personality"> Energetic</label><br> | 
					
						
							|  |  |  |     <input type="text" placeholder="cat photo URL" required> | 
					
						
							|  |  |  |     <button type="submit">Submit</button> | 
					
						
							|  |  |  |   </form> | 
					
						
							|  |  |  | </main> | 
					
						
							|  |  |  | ``` |