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

2.5 KiB
Raw Blame History

id title challengeType forumTopicId dashedName
587d7fa5367417b2b2512bbd 将一组CSS样式扩展到另一个元素 0 301456 extend-one-set-of-css-styles-to-another-element

--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)
);

--seed--

--seed-contents--

<style type='text/scss'>
  h3{
    text-align: center;
  }
  .info{
    width: 200px;
    border: 1px solid black;
    margin: 0 auto;
  }




</style>
<h3>Posts</h3>
<div class="info-important">
  <p>This is an important post. It should extend the class ".info" and have its own CSS styles.</p>
</div>

<div class="info">
  <p>This is a simple post. It has basic styling and can be extended for other uses.</p>
</div>

--solutions--

<style type='text/scss'>
  h3{
    text-align: center;
  }
  .info{
    width: 200px;
    border: 1px solid black;
    margin: 0 auto;
  }
  .info-important{
    @extend .info;
    background-color: magenta;
  }



</style>
<h3>Posts</h3>
<div class="info-important">
  <p>This is an important post. It should extend the class ".info" and have its own CSS styles.</p>
</div>

<div class="info">
  <p>This is a simple post. It has basic styling and can be extended for other uses.</p>
</div>