Skip to content

Commit

Permalink
2024/12/20 時点の英語版に基づき更新
Browse files Browse the repository at this point in the history
  • Loading branch information
mfuji09 committed Dec 30, 2024
1 parent dc5fb29 commit 1f90f63
Show file tree
Hide file tree
Showing 5 changed files with 943 additions and 115 deletions.
Original file line number Diff line number Diff line change
@@ -1,19 +1,18 @@
---
title: "スキルテスト: セレクター"
slug: Learn_web_development/Core/Styling_basics/Basic_selectors/Selectors_Tasks
original_slug: Learn/CSS/Building_blocks/Selectors/Selectors_Tasks
l10n:
sourceCommit: c64e813d8ab9dbe22cbc049c26f7c6703370a2b7
sourceCommit: 5b20f5f4265f988f80f513db0e4b35c7e0cd70dc
---

{{LearnSidebar}}

このスキルテストの目的は、 [CSS セレクター](/ja/docs/Learn/CSS/Building_blocks/Selectors)を理解しているかどうかを評価することです。
このスキルテストの目的は、 [CSS セレクター](/ja/docs/Learn_web_development/Core/Styling_basics/Basic_selectors)を理解しているかどうかを評価することです。

> [!NOTE]
> このページのインタラクティブエディターや、[CodePen](https://codepen.io/)[JSFiddle](https://jsfiddle.net/)[Glitch](https://glitch.com/) などのオンラインエディターで解決策を試すことができます
>
> もし行き詰まったら[コミュニケーションチャンネル](/ja/docs/MDN/Community/Communication_channels)のいずれかに連絡してみてください
> 以下のコードブロックで **"Play"** をクリックすると、 MDN Playground で例を編集することができます
> コードをコピー(クリップボードアイコンをクリック)し、[CodePen](https://codepen.io/)[JSFiddle](https://jsfiddle.net/)[Glitch](https://glitch.com/) などのオンラインエディターに貼り付けることもできます。
> 行き詰まった場合は[コミュニケーションチャンネル](/ja/docs/MDN/Community/Communication_channels)のいずれかに連絡してください
## 課題 1

Expand All @@ -29,11 +28,53 @@ l10n:

以下のライブコードを更新して、完成例を再現してみてください。

{{EmbedGHLiveSample("css-examples/learn/tasks/selectors/type.html", '100%', 700)}}

> [!CALLOUT]
>
> 自分自身のエディターやオンラインエディターで作業する場合は、[このタスクの開始点をダウンロード](https://github.com/mdn/css-examples/blob/main/learn/tasks/selectors/type-download.html)しましょう。
```html live-sample___type
<div class="container">
<h1>これは見出しです</h1>
<p>
Veggies es <span>bonus vobis</span>, proinde vos postulo essum magis
kohlrabi welsh onion daikon amaranth tatsoi tomatillo melon azuki bean
garlic.
</p>
<h2>これはレベル 2 の見出しです</h2>
<p>
Gumbo beet greens corn soko endive gumbo gourd. Parsley shallot courgette
tatsoi pea sprouts fava bean collard greens dandelion okra wakame tomato.
Dandelion cucumber earthnut pea peanut soko zucchini.
</p>
</div>
```

```css live-sample___type
body {
font: 1.2em / 1.5 sans-serif;
}
/* Add styles here */
```

{{EmbedLiveSample("type", "", "260px")}}

<details>
<summary>ここをクリックすると、解決策を表示します。</summary>

色やサイズを変更するには、`h1``h2``span` セレクターを対象とする必要があります。

```css
h1 {
color: blue;
}

h2 {
background-color: blue;
color: white;
}

span {
font-size: 200%;
}
```

</details>

## 課題 2

Expand All @@ -50,11 +91,58 @@ l10n:

以下のライブコードを更新して、完成例を再現してみてください。

{{EmbedGHLiveSample("css-examples/learn/tasks/selectors/class-id.html", '100%', 800)}}

> [!CALLOUT]
>
> 自分自身のエディターやオンラインエディターで作業する場合は、[このタスクの開始点をダウンロード](https://github.com/mdn/css-examples/blob/main/learn/tasks/selectors/class-id-download.html)しましょう。
```html live-sample___class-id
<div class="container">
<h1>これは見出しです</h1>
<p>
Veggies es <span class="alert">bonus vobis</span>, proinde vos postulo
<span class="alert stop">essum magis</span> kohlrabi welsh onion daikon
amaranth tatsoi tomatillo melon azuki bean garlic.
</p>
<h2 id="special">これはレベル 2 の見出しです</h2>
<p>Gumbo beet greens corn soko endive gumbo gourd.</p>
<h2>他のレベル 2 の見出しです</h2>
<p>
<span class="alert go">Parsley shallot</span> courgette tatsoi pea sprouts
fava bean collard greens dandelion okra wakame tomato. Dandelion cucumber
earthnut pea peanut soko zucchini.
</p>
</div>
```

```css live-sample___class-id
body {
font: 1.2em / 1.5 sans-serif;
}
/* Add styles here */
```

{{EmbedLiveSample("class-id", "", "320px")}}

<details>
<summary>ここをクリックすると、解決策を表示します。</summary>

これは、クラスセレクターと ID セレクターの違いを理解しているか、また、アイテムの複数のクラスを対象とする方法を理解しているかを検査するものです。

```css
#special {
background-color: yellow;
}

.alert {
border: 2px solid grey;
}

.alert.stop {
background-color: red;
}

.alert.go {
background-color: green;
}
```

</details>

## 課題 3

Expand All @@ -70,11 +158,109 @@ l10n:

以下のライブコードを更新して、完成例を再現してみてください。

{{EmbedGHLiveSample("css-examples/learn/tasks/selectors/pseudo.html", '100%', 800)}}

> [!CALLOUT]
>
> 自分自身のエディターやオンラインエディターで作業する場合は、[このタスクの開始点をダウンロード](https://github.com/mdn/css-examples/blob/main/learn/tasks/selectors/pseudo-download.html)しましょう。
```html live-sample___pseudo
<div class="container">
<p>
Veggies es <a href="http://example.com">bonus vobis</a>, proinde vos postulo
essum magis kohlrabi welsh onion daikon amaranth tatsoi tomatillo melon
azuki bean garlic.
</p>
<p>
Gumbo beet greens corn soko endive gumbo gourd. Parsley shallot courgette
tatsoi pea sprouts fava bean collard greens dandelion okra wakame tomato.
Dandelion cucumber earthnut pea peanut soko zucchini.
</p>
<table>
<tbody>
<tr>
<th>果物</th>
<th>野菜</th>
</tr>
<tr>
<td>りんご</td>
<td>じゃがいも</td>
</tr>
<tr>
<td>オレンジ</td>
<td>人参</td>
</tr>
<tr>
<td>トマト</td>
<td>西洋人参</td>
</tr>
<tr>
<td>キウイ</td>
<td>タマネギ</td>
</tr>
<tr>
<td>バナナ</td>
<td>赤かぶ</td>
</tr>
</tbody>
</table>
</div>
```

```css hidden live-sample___pseudo
body {
font: 1.2em / 1.5 sans-serif;
}
* {
box-sizing: border-box;
}

table {
border-collapse: collapse;
width: 300px;
}

td,
th {
padding: 0.2em;
text-align: left;
}
```

```css live-sample___pseudo
/* Add styles here */
```

{{EmbedLiveSample("pseudo", "", "320px")}}

<details>
<summary>ここをクリックすると、解決策を表示します。</summary>

コンテンツに擬似クラス (`:first-child`) と擬似要素 (`::first-line`) を適用します。
`a` 要素の`:link``:visited``:hover`の状態にスタイル設定を行い、 `:nth-child` 擬似クラスを使用して表の行を縞模様にします。

```css
.container p:first-child {
font-size: 150%;
}

.container p:first-child::first-line {
color: red;
}

a:link {
color: orange;
}

a:visited {
color: green;
}

a:hover {
text-decoration: none;
}

tr:nth-child(even) {
background-color: #333;
color: #fff;
}
```

</details>

## 課題 4

Expand All @@ -89,11 +275,55 @@ l10n:

以下のライブコードを更新して、完成例を再現してみてください。

{{EmbedGHLiveSample("css-examples/learn/tasks/selectors/combinators.html", '100%', 800)}}

> [!CALLOUT]
>
> 自分自身のエディターやオンラインエディターで作業する場合は、[このタスクの開始点をダウンロード](https://github.com/mdn/css-examples/blob/main/learn/tasks/selectors/combinators-download.html)しましょう。
```html live-sample___combinators
<div class="container">
<h2>これは見出しです</h2>
<p>見出しの後の段落です。</p>
<p>これは 2 番目の段落です。</p>

<h2>もう一つの見出し</h2>
<p>見出しの後の段落です。</p>
<ul class="list">
<li>One</li>
<li>
Two
<ul>
<li>2.1</li>
<li>2.2</li>
</ul>
</li>
<li>Three</li>
</ul>
</div>
```

```css live-sample___combinators
body {
font: 1.2em / 1.5 sans-serif;
}
/* Add styles here */
```

{{EmbedLiveSample("combinators", "", "350px")}}

<details>
<summary>ここをクリックすると、解決策を表示します。</summary>

この課題では、さまざまな結合子を使用する方法を理解しているか調べます。
適切な解答は次の通りです。

```css
h2 + p {
color: red;
}

.list > li {
list-style: none;
border-bottom: 1px solid #ccc;
}
```

</details>

## 課題 5

Expand All @@ -109,8 +339,70 @@ l10n:

以下のライブコードを更新して、完成例を再現してみてください。

{{EmbedGHLiveSample("css-examples/learn/tasks/selectors/attribute-links.html", '100%', 800)}}

> [!CALLOUT]
>
> 自分自身のエディターやオンラインエディターで作業する場合は、[このタスクの開始点をダウンロード](https://github.com/mdn/css-examples/blob/main/learn/tasks/selectors/attribute-links-download.html)しましょう。
```html live-sample___attribute-links
<ul>
<li><a href="https://example.com">Link 1</a></li>
<li><a href="http://example.com" title="Visit example.com">Link 2</a></li>
<li><a href="/contact">Link 3</a></li>
<li><a href="../contact/index.html">Link 4</a></li>
</ul>
```

```css hidden live-sample___attribute-links
body {
font: 1.2em / 1.5 sans-serif;
}

ul {
list-style: none;
margin: 0;
padding: 0;
}

li {
margin: 0 0 0.5em 0;
}

a {
display: block;
padding: 0.5em;
}
```

```css live-sample___attribute-links
a {
border: 5px solid grey;
}
/* Add styles here */
```

{{EmbedLiveSample("attribute-links", "", "300px")}}

<details>
<summary>ここをクリックすると、解決策を表示します。</summary>

- title 属性を持つ要素を選択するには、角カッコ内に title を追加します (`a[title]`)。これにより、唯一タイトル属性を持つ 2 つ目のリンクが選択されます。

- `<a>` 要素の `href` 属性の値のどこかに "contact" という語が格納されている要素を対象とし、境界線をオレンジ色 (`border-color: orange`) にします。
ここで照合したいのは、 href 値の `/contact``../contact` の 2 つです。そのため、値のどこかに文字列 "contact" が含まれていることを照合する必要があり、 `*=` を使用します。これにより 3 つ目と 4 つ目のリンクが選択されます。

- `<a>` 要素の `href` 値が `https` で始まるものを対象とし、緑色の境界線 (`border-color: green`) を設定します。
`href` 値が "https" で始まるものを探していくには、最初のリンクのみを選択するために `^=` を使用します。

```css
a[title] {
border-color: pink;
}
a[href*="contact"] {
border-color: orange;
}
a[href^="https"] {
border-color: green;
}
```

</details>

## 関連情報

- [CSS によるスタイル設定の基本](/ja/docs/Learn_web_development/Core/Styling_basics)
Loading

0 comments on commit 1f90f63

Please sign in to comment.