179 lines
4.0 KiB
Markdown
179 lines
4.0 KiB
Markdown
|
---
|
||
|
id: 615f7de4487b64919bb4aa5e
|
||
|
title: Passo 52
|
||
|
challengeType: 0
|
||
|
dashedName: step-52
|
||
|
---
|
||
|
|
||
|
# --description--
|
||
|
|
||
|
Após o último `.divider`, crie um elemento `p` com o texto `Cholesterol 0mg 0%`. Encapsule o texto `Cholesterol` em um elemento `span`, e dê a ele o elemento `span` com o atributo `class` definido como `bold`. Encapsule o texto `0%` em outro elemento `span`, com a `class` definida como `bold right`.
|
||
|
|
||
|
# --hints--
|
||
|
|
||
|
Você deve criar um elemento `p` no final do elemento `.daily-value.sm-text`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.localName === 'p');
|
||
|
```
|
||
|
|
||
|
O novo elemento `p` deve ter o texto `Cholesterol 0mg 0%`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.innerText?.match(/Cholesterol 0mg[\s|\n]+0%/));
|
||
|
```
|
||
|
|
||
|
O novo elemento `p` deve ter dois elementos `span`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.querySelectorAll('span')?.length === 2);
|
||
|
```
|
||
|
|
||
|
O primeiro elemento `span` deve ter o atributo `class` definido como `bold`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.firstElementChild?.classList?.contains('bold'));
|
||
|
```
|
||
|
|
||
|
O primeiro elemento `span` deve encapsular o texto `Cholesterol`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.firstElementChild?.innerText === 'Cholesterol');
|
||
|
```
|
||
|
|
||
|
O segundo elemento `span` deve ter o atributo `class` definido como `bold right`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.lastElementChild?.classList?.contains('bold'));
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.lastElementChild?.classList?.contains('right'));
|
||
|
```
|
||
|
|
||
|
O segundo elemento `span` deve encapsular o texto `0%`.
|
||
|
|
||
|
```js
|
||
|
assert(document.querySelector('.daily-value.sm-text')?.lastElementChild?.lastElementChild?.innerText === '0%');
|
||
|
```
|
||
|
|
||
|
# --seed--
|
||
|
|
||
|
## --seed-contents--
|
||
|
|
||
|
```html
|
||
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta charset="UTF-8">
|
||
|
<title>Nutrition Label</title>
|
||
|
<link href="https://fonts.googleapis.com/css?family=Open+Sans:400,700,800" rel="stylesheet">
|
||
|
<link href="./styles.css" rel="stylesheet">
|
||
|
</head>
|
||
|
<body>
|
||
|
<div class="label">
|
||
|
<header>
|
||
|
<h1 class="bold">Nutrition Facts</h1>
|
||
|
<div class="divider"></div>
|
||
|
<p>8 servings per container</p>
|
||
|
<p class="bold">Serving size <span class="right">2/3 cup (55g)</span></p>
|
||
|
</header>
|
||
|
<div class="divider lg"></div>
|
||
|
<div class="calories-info">
|
||
|
<p class="bold sm-text">Amount per serving</p>
|
||
|
<h1>Calories <span class="right">230</span></h1>
|
||
|
</div>
|
||
|
<div class="divider md"></div>
|
||
|
<div class="daily-value sm-text">
|
||
|
--fcc-editable-region--
|
||
|
<p class="right bold no-divider">% Daily Value *</p>
|
||
|
<div class="divider"></div>
|
||
|
<p><span class="bold">Total Fat</span> 8g<span class="bold right">10%</span></p>
|
||
|
<p class="indent no-divider">Saturated Fat 1g <span class="bold right">5%</span></p>
|
||
|
<div class="divider"></div>
|
||
|
<p class="indent no-divider"><i>Trans</i> Fat 0g</p>
|
||
|
<div class="divider"></div>
|
||
|
--fcc-editable-region--
|
||
|
</div>
|
||
|
</div>
|
||
|
</body>
|
||
|
</html>
|
||
|
```
|
||
|
|
||
|
```css
|
||
|
* {
|
||
|
box-sizing: border-box;
|
||
|
}
|
||
|
|
||
|
html {
|
||
|
font-size: 16px;
|
||
|
}
|
||
|
|
||
|
body {
|
||
|
font-family: 'Open Sans', sans-serif;
|
||
|
}
|
||
|
|
||
|
.label {
|
||
|
border: 2px solid black;
|
||
|
width: 270px;
|
||
|
margin: 20px auto;
|
||
|
padding: 0 7px;
|
||
|
}
|
||
|
|
||
|
header h1 {
|
||
|
text-align: center;
|
||
|
margin: -4px 0;
|
||
|
letter-spacing: 0.15px
|
||
|
}
|
||
|
|
||
|
p {
|
||
|
margin: 0;
|
||
|
}
|
||
|
|
||
|
.divider {
|
||
|
border-bottom: 1px solid #888989;
|
||
|
margin: 2px 0;
|
||
|
clear: right;
|
||
|
}
|
||
|
|
||
|
.bold {
|
||
|
font-weight: 800;
|
||
|
}
|
||
|
|
||
|
.right {
|
||
|
float: right;
|
||
|
}
|
||
|
|
||
|
.lg {
|
||
|
height: 10px;
|
||
|
}
|
||
|
|
||
|
.lg, .md {
|
||
|
background-color: black;
|
||
|
border: 0;
|
||
|
}
|
||
|
|
||
|
.md {
|
||
|
height: 5px;
|
||
|
}
|
||
|
|
||
|
.sm-text {
|
||
|
font-size: 0.85rem;
|
||
|
}
|
||
|
|
||
|
.calories-info h1 {
|
||
|
margin: -5px -2px;
|
||
|
overflow: hidden;
|
||
|
}
|
||
|
|
||
|
.calories-info span {
|
||
|
font-size: 1.2em;
|
||
|
margin-top: -7px;
|
||
|
}
|
||
|
|
||
|
.indent {
|
||
|
margin-left: 1em;
|
||
|
}
|
||
|
|
||
|
.daily-value p:not(.no-divider) {
|
||
|
border-bottom: 1px solid #888989;
|
||
|
}
|
||
|
```
|