Espace entre la bordure et l'élément enfant avec le rayon de la bordure

Nov 27 2020

J'essaie d'implémenter des boutons radio qui fonctionnent comme des contrôles segmentés:

* {
  margin: 0;
  padding: 0;
}

.container {
  background-color: brown;
  width: 80vw;
}

.box {
  display: flex;
  flex-direction: row;
  border: 2rem solid skyblue;
  border-radius: 999px;
}

label {
  flex: 1;
  padding: 2rem;
  border-radius: 999px;
  text-align: center;
}

input {
  display: none;
}

input:checked + label {
  background-color: skyblue;
}
<div class="container">
  <div class="box">
    <input type="radio" id="hello" name="test" checked />
    <label for="hello">Hello</label>
    
    <input type="radio" id="world" name="test" />
    <label for="world">World</label>
  </div>
</div>

Cependant, il y a un écart gênant d'environ 1px entre l'étiquette imbriquée et le div parent:

Ce problème est similaire à cette question , mais les solutions de contournement suggérées ne fonctionnent pas vraiment pour mon cas d'utilisation car je ne peux pas changer la couleur d'arrière-plan. Je suis également curieux de savoir s'il s'agit d'un bogue du navigateur ou d'un problème d'anti-aliasing.

Réponses

2 ArhamChowdhury Nov 27 2020 at 13:23

ajoutez simplement une ombre de boîte à l'entrée: check + label

input:checked + label {
    background-color: skyblue;
    box-shadow: 0px 0px 0 1px skyblue;
}

Lien vers Jsfiddle

1 TanishSurana Nov 27 2020 at 12:42

Je ne sais pas pourquoi vous obtenez cet écart de 1 px mais vous pouvez ajouter "transform: translateX (-1px);" pour le décaler vers la gauche de 1px. Cela peut fonctionner comme une solution temporaire.

  label {
    flex: 1;
    padding: 2rem;
    border-radius: 200px;
    text-align: center;
    transform: translateX(-1px);
  }
LaljiTadhani Nov 27 2020 at 12:57

Changer label border-radius 999pxpour35px

label {
      flex: 1;
      padding: 2rem;
      border-radius: 35px;
      text-align: center;
    }

* {
  margin: 0;
  padding: 0;
}

.container {
  background-color: brown;
  width: 80vw;
}

.box {
  display: flex;
  flex-direction: row;
  border: 2rem solid skyblue;
  border-radius: 999px;
}

label {
  flex: 1;
  padding: 2rem;
  border-radius: 35px;
  text-align: center;
}

input {
  display: none;
}

input:checked + label {
  background-color: skyblue;
}
<div class="container">
  <div class="box">
    <input type="radio" id="hello" name="test" checked />
    <label for="hello">Hello</label>
    
    <input type="radio" id="world" name="test" />
    <label for="world">World</label>
  </div>
</div>