2.4 KiB
2.4 KiB
id, title, challengeType, videoUrl, forumTopicId, dashedName
id | title | challengeType | videoUrl | forumTopicId | dashedName |
---|---|---|---|---|---|
bad87fee1348bd9aedf07756 | Important 的優先級最高 | 0 | https://scrimba.com/c/cm24rcp | 18249 | override-all-other-styles-by-using-important |
--description--
耶! 我們剛剛又證明了行內樣式會覆蓋 style
標籤裏面所有的 CSS 聲明。
不過, 還有一種方式可以覆蓋重新 CSS 樣式。 這是所有方法裏面最強大的一個。 在此之前,我們要考慮清楚,爲什麼我們要覆蓋 CSS 樣式。
很多時候,你會使用 CSS 庫, CSS 庫中的樣式會意外覆蓋你的 CSS 樣式。 如果想保證你的 CSS 樣式不受影響,你可以使用 !important
。
讓我們回到 pink-text
類聲明。 pink-text
類的顏色樣式已被之後的 class 聲明、id 聲明以及行內樣式所覆蓋。
--instructions--
給粉紅文本元素的顏色聲明添加關鍵詞 !important
,以確保 h1
元素爲粉紅色。
如下所示:
color: red !important;
--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
元素應有一個內聯樣式 color: white
。
assert(code.match(/<h1.*style/gi) && code.match(/<h1.*style.*color\s*?:/gi));
pink-text
class 應有 !important
關鍵詞 ,以覆蓋其他聲明。
assert(
code.match(/\.pink-text\s*?\{[\s\S]*?color:.*pink.*!important\s*;?[^\.]*\}/g)
);
h1
元素應爲粉紅色。
assert($('h1').css('color') === 'rgb(255, 192, 203)');
--seed--
--seed-contents--
<style>
body {
background-color: black;
font-family: monospace;
color: green;
}
#orange-text {
color: orange;
}
.pink-text {
color: pink;
}
.blue-text {
color: blue;
}
</style>
<h1 id="orange-text" class="pink-text blue-text" style="color: white">Hello World!</h1>
--solutions--
<style>
body {
background-color: black;
font-family: monospace;
color: green;
}
#orange-text {
color: orange;
}
.pink-text {
color: pink !important;
}
.blue-text {
color: blue;
}
</style>
<h1 id="orange-text" class="pink-text blue-text" style="color: white">Hello World!</h1>