freeCodeCamp/curriculum/challenges/chinese/01-responsive-web-design/basic-css/override-class-declarations...

1.7 KiB
Raw Blame History

id title challengeType videoUrl forumTopicId
bad87fee1348bd8aedf06756 ID 选择器优先级高于 Class 选择器 0 https://scrimba.com/c/cRkpDhB 18251

--description--

我们刚刚证明了浏览器读取 CSS 是由上到下的。这就意味着,如果发生冲突,浏览器将会应用最后声明的样式。

不过我们还没结束,还有其他方法来覆盖 CSS 样式。你还记得 id 属性吗?

通过给 h1 元素添加 id 属性,我们便可以此来覆盖 class 属性中定义的同名样式。

--instructions--

h1 元素添加 id 属性,属性值为 orange-text。设置方式如下:

<h1 id="orange-text">

h1 元素应继续保留 blue-textpink-text 这两个 class。

style 元素中创建名为 orange-text 的 id 选择器。例子如下:

#brown-text {
  color: brown;
}

**注意:**无论在 pink-text class 之前或者之后声明id 选择器的优先级总是高于 class 选择器。

--hints--

h1 元素应包含 pink-text class。

assert($('h1').hasClass('pink-text'));

h1 元素应包含 blue-text class。

assert($('h1').hasClass('blue-text'));

h1 的 id 属性值应为 orange-text

assert($('h1').attr('id') === 'orange-text');

应只有一个 h1 元素。

assert($('h1').length === 1);

应存在名为 orange-text 的 id 选择器。

assert(code.match(/#orange-text\s*{/gi));

不要在 h1 元素里面使用行内样式。

assert(!code.match(/<h1.*style.*>/gi));

h1 元素的字体颜色应为橘色。

assert($('h1').css('color') === 'rgb(255, 165, 0)');

--solutions--