freeCodeCamp/curriculum/challenges/chinese/03-front-end-libraries/sass/extend-one-set-of-css-style...

1.5 KiB
Raw Blame History

id title challengeType forumTopicId
587d7fa5367417b2b2512bbd 将一组CSS样式扩展到另一个元素 0 301456

--description--

Sass 有一个名为extend的功能,可以很容易地从一个元素中借用 CSS 规则并在另一个元素上重用它们。

例如,下面的 CSS 规则块设置了.panelclass 的样式。它有background-colorheightborder

.panel{
  background-color: red;
  height: 70px;
  border: 2px solid green;
}

现在你需要另一个名为.big-panel的面板。它具有与.panel相同的基本属性,但还需要widthfont-size。 可以从.panel复制并粘贴初始 CSS 规则,但是当你添加更多类型的面板时,代码会变得重复。 extend指令是一种重用为一个元素编写的规则的简单方法,然后为另一个元素添加更多:

.big-panel{
  @extend .panel;
  width: 150px;
  font-size: 2em;
}

除了新样式之外,.big-panel将具有与.panel相同的属性。

--instructions--

创建一个扩展.info的 class.info-important,并将background-color设置为洋红色。

--hints--

info-importantclass 应该将background-color设置为magenta

assert(
  code.match(
    /\.info-important\s*?{[\s\S]*background-color\s*?:\s*?magenta\s*?;[\s\S]*}/gi
  )
);

info-importantclass 应使用@extend继承infoclass 的样式。

assert(
  code.match(/\.info-important\s*?{[\s\S]*@extend\s*?.info\s*?;[\s\S]*/gi)
);

--solutions--