2018-10-10 22:03:03 +00:00
|
|
|
|
---
|
|
|
|
|
id: bad87fee1348bd8aedf06756
|
2020-12-16 07:37:30 +00:00
|
|
|
|
title: ID 选择器优先级高于 Class 选择器
|
2018-10-10 22:03:03 +00:00
|
|
|
|
challengeType: 0
|
2019-12-13 05:47:57 +00:00
|
|
|
|
videoUrl: 'https://scrimba.com/c/cRkpDhB'
|
|
|
|
|
forumTopicId: 18251
|
2018-10-10 22:03:03 +00:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --description--
|
|
|
|
|
|
2019-12-13 05:47:57 +00:00
|
|
|
|
我们刚刚证明了浏览器读取 CSS 是由上到下的。这就意味着,如果发生冲突,浏览器将会应用最后声明的样式。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
2019-12-13 05:47:57 +00:00
|
|
|
|
不过我们还没结束,还有其他方法来覆盖 CSS 样式。你还记得 id 属性吗?
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
通过给 `h1` 元素添加 id 属性,我们便可以此来覆盖 class 属性中定义的同名样式。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
# --instructions--
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
给 `h1` 元素添加 id 属性,属性值为 `orange-text`。设置方式如下:
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
`<h1 id="orange-text">`
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
`h1` 元素应继续保留 `blue-text` 和 `pink-text` 这两个 class。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
在 `style` 元素中创建名为 `orange-text` 的 id 选择器。例子如下:
|
2019-12-13 05:47:57 +00:00
|
|
|
|
|
|
|
|
|
```css
|
|
|
|
|
#brown-text {
|
|
|
|
|
color: brown;
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
**注意:**无论在 `pink-text` class 之前或者之后声明,id 选择器的优先级总是高于 class 选择器。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
# --hints--
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
`h1` 元素应包含 `pink-text` class。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert($('h1').hasClass('pink-text'));
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
`h1` 元素应包含 `blue-text` class。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert($('h1').hasClass('blue-text'));
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
`h1` 的 id 属性值应为 `orange-text`。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert($('h1').attr('id') === 'orange-text');
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
应只有一个 `h1` 元素。
|
2020-12-16 07:37:30 +00:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert($('h1').length === 1);
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```
|
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
应存在名为 `orange-text` 的 id 选择器。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(code.match(/#orange-text\s*{/gi));
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
不要在 `h1` 元素里面使用行内样式。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert(!code.match(/<h1.*style.*>/gi));
|
|
|
|
|
```
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2021-01-08 19:20:48 +00:00
|
|
|
|
`h1` 元素的字体颜色应为橘色。
|
2018-10-10 22:03:03 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
```js
|
|
|
|
|
assert($('h1').css('color') === 'rgb(255, 165, 0)');
|
2018-10-10 22:03:03 +00:00
|
|
|
|
```
|
2019-12-13 05:47:57 +00:00
|
|
|
|
|
2020-12-16 07:37:30 +00:00
|
|
|
|
# --solutions--
|
|
|
|
|
|