2.5 KiB
2.5 KiB
id, title, challengeType, videoUrl, forumTopicId, dashedName
id | title | challengeType | videoUrl | forumTopicId | dashedName |
---|---|---|---|---|---|
bad87fee1348bd8aedf06756 | ID 選擇器優先級高於 Class 選擇器 | 0 | https://scrimba.com/c/cRkpDhB | 18251 | override-class-declarations-by-styling-id-attributes |
--description--
我們剛剛證明了瀏覽器讀取 CSS 是由上到下的。 這就意味着,如果發生衝突,瀏覽器將會應用最後聲明的樣式。 注意,如果我們在 h1
元素的類中,將 blue-text
放置在 pink-text
之前,它仍然會檢查聲明順序,而不是使用順序!
但我們還沒有完成。 其實還有其他方法可以覆蓋 CSS 樣式。 你還記得 id 屬性嗎?
我們來通過給 h1
元素添加 id 屬性,覆蓋 pink-text
和 blue-text
類,使 h1
元素變成橘色。
--instructions--
給 h1
元素添加 id
屬性,屬性值爲 orange-text
。 設置方式如下:
<h1 id="orange-text">
h1
元素需繼續保留 blue-text
和 pink-text
這兩個 class。
在 style
元素中創建名爲 orange-text
的 id 選擇器。 例子如下:
#brown-text {
color: brown;
}
注意: 無論在 pink-text
class 之前或者之後聲明,id
選擇器的優先級總是高於 class 選擇器。
--hints--
h1
元素的應有一個 class 爲 pink-text
。
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
元素裏面使用 style
屬性。
assert(!code.match(/<h1.*style.*>/gi));
h1
元素的字體顏色應爲橘色。
assert($('h1').css('color') === 'rgb(255, 165, 0)');
--seed--
--seed-contents--
<style>
body {
background-color: black;
font-family: monospace;
color: green;
}
.pink-text {
color: pink;
}
.blue-text {
color: blue;
}
</style>
<h1 class="pink-text blue-text">Hello World!</h1>
--solutions--
<style>
body {
background-color: black;
font-family: monospace;
color: green;
}
.pink-text {
color: pink;
}
.blue-text {
color: blue;
}
#orange-text {
color: orange;
}
</style>
<h1 id="orange-text" class="pink-text blue-text">Hello World!</h1>