Hoe maak je spoilertekst aan?

Hallo, ik vroeg me af hoe ik spoilertekst op een website kan maken met html/css. Wat ik was, is tekst die zwart is met een zwarte achtergrond, maar als je erover zweeft, wordt de zwarte tekst wit, waardoor deze zichtbaar wordt.

zoals dit

<span style="color: black; background: black;">test</span>
<p>Then when hovered over</p>
<span style="color: white; background: black;">test</span>

Antwoord 1, autoriteit 100%

.spoiler, .spoiler2{ 
  color: black; 
  background-color:black;
}
.spoiler:hover{
  color: white;
  }
.spoiler2:hover { 
  background-color:white; 
  }
<span class="spoiler" >test</span>
<p>Then when hovered over</p>
<span class="spoiler2"> other test </span>

Antwoord 2, autoriteit 97%

De <details>HTML-tag is speciaal voor dit doel ontworpen. Hier is het voorbeeld uit de MDN-documenten. Helaas ondersteunen IE en edge deze tag niet vanaf januari 2019.

<details>
    <summary>Details</summary>
    Something small enough to escape casual notice.
</details>

Antwoord 3, autoriteit 7%

Ik heb spoilers gebruikt op forums (inclusief die van mij) die niet alleen uit tekst bestaan met een gewijzigde achtergrondkleur.

Ze hebben de inhoud verborgen totdat u op een wisselknop voor weergeven/verbergen klikt.

Ik wil een sectie toevoegen aan een site die niet standaard wordt weergegeven om ruimte te besparen.

https://jsfiddle.net/clarle/bY7m4/

Het lijkt erop dat het aan mijn behoeften zal voldoen.

HTML

<div class="forum-post">
    <a href="#hide" class="hide btn" id="hide">Show spoiler</a>
    <a href="#show" class="show btn" id="show">Hide spoiler</a>
    <div class="spoiler">
      <p class="spoiler-content">People die when they are killed!</p>
    </div>
</div>

CSS

.spoiler {
  display: none;
}
.show {
  display: none; 
}
.hide:target + .show {
  display: inline; 
}
.hide:target {
  display: none; 
}
.hide:target ~ .spoiler {
  display: inline;
}
/* Just for prettiness, not actually needed */
body {
  margin: 0;
  padding: 20px;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 20px;
  color: #333333;
  background-color: #ffffff;
}
.btn {
  padding: 4px 12px;
  margin-bottom: 0;
  *margin-left: .3em;
  font-size: 14px;
  line-height: 20px;
  color: #333333;
  text-align: center;
  text-shadow: 0 1px 1px rgba(255, 255, 255, 0.75);
  vertical-align: middle;
  cursor: pointer;
  background-color: #f5f5f5;
  *background-color: #e6e6e6;
  background-image: -moz-linear-gradient(top, #ffffff, #e6e6e6);
  background-image: -webkit-gradient(linear, 0 0, 0 100%, from(#ffffff), to(#e6e6e6));
  background-image: -webkit-linear-gradient(top, #ffffff, #e6e6e6);
  background-image: -o-linear-gradient(top, #ffffff, #e6e6e6);
  background-image: linear-gradient(to bottom, #ffffff, #e6e6e6);
  background-repeat: repeat-x;
  border: 1px solid #bbbbbb;
  *border: 0;
  border-color: #e6e6e6 #e6e6e6 #bfbfbf;
  border-color: rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.1) rgba(0, 0, 0, 0.25);
  border-bottom-color: #a2a2a2;
  -webkit-border-radius: 4px;
     -moz-border-radius: 4px;
          border-radius: 4px;
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#ffe6e6e6', GradientType=0);
  filter: progid:DXImageTransform.Microsoft.gradient(enabled=false);
  *zoom: 1;
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
     -moz-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.2), 0 1px 2px rgba(0, 0, 0, 0.05);
  text-decoration: none;
}
.forum-post {
  padding: 20px;
  border: 1px solid #000;
}
.spoiler-content {
  padding: 15px;
}

Antwoord 4

Het selectievakje gebruiken als spoiler verbergen of weergeven

Als je dat niet wilt weten, kun je ook de checkbox gebruiken om spoilers te maken.
Het is ook heel eenvoudig.

#spoilerdiv1 {
  background-color: lightgray;
  padding: 2.5px;
  visibility: hidden;
  margin-top: 10px;
}
#spoilercheck1:checked ~ #spoilerdiv1 {
  visibility: visible;
}
<h1>An example HTML Spoiler</h1>
<input type="checkbox" name="spoiler-one" id="spoilercheck1">
<div id="spoilerdiv1">
  <p>This is the spoiler content</p>
</div>

Other episodes