HTML+CSS实现选项卡效果

Chanx 423 字 2 分钟阅读

不使用Javascript,如何实现选项卡效果呢?

具体效果:

Snipaste_2020-09-13_16-48-03

本文将不会使用到js,使用html+css完成所需效果。你可能会有疑问不使用js的情况下,怎么实现点击切换的效果?

首先我们要知道,单选框选项组是怎么写的

<input type="radio" name="items" id="item1" value="1"/>
<input type="radio" name="items" id="item2" value="2"/>
<input type="radio" name="items" id="item3" value="3"/>

另外我们要知道一个非常重要的<label>for属性

<input type="radio" name="items" id="item1" value="1"/>
<input type="radio" name="items" id="item2" value="2"/>
<input type="radio" name="items" id="item3" value="3"/>
 
<label for="item1">choose item1</label>
<label for="item2">choose item2</label>
<label for="item3">choose item3</label>

点击相应的<label>相应的单选框将会被选中

有了它,我们就可以进一步发挥想象的空间 => 一个label相当于一个tab选项卡

然后就是我们选项卡的内容了,将每一个卡的内容视为一张卡片

我们把卡片叠到一起,只要其中一张不透明,其余卡片都透明就可以实现选择效果

如何实现透明度的切换,就需要利用到radiochecked这么一个CSS属性

剩余的浏览代码就可以明白啦

<div id="swiper">
  <input id="item1" type="radio" name="1" value="1" style="display: none;" checked/>
  <input id="item2" type="radio" name="1" value="2" style="display: none;"/>
  <input id="item3" type="radio" name="1" value="3" style="display: none;"/>
  <div class="pic">
    <img id="pic1" src="./images/w01.jpg">
    <img id="pic2" src="./images/w02.jpg">
    <img id="pic3" src="./images/w03.jpg">
    <div class="pic-btn">
      <label id="btn1" for="item1"></label>
      <label id="btn2" for="item2"></label>
      <label id="btn3" for="item3"></label>
    </div>
  </div>
</div>
.pic img{
  opacity: 0;/*默认所有卡片都透明*/
  width: 100%;
  height: 100%;
  transition: all 0.6s;
  position: absolute;
  top: 0;
  left: 0;
}
 
#item1:checked~.pic #pic1,
#item2:checked~.pic #pic2,
#item3:checked~.pic #pic3{
  opacity: 1;//被选中的卡片透明度为1
  transition: all 0.6s;
}
 
/*选项条居中*/
.pic-btn{
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}
 
.pic-btn label{
  width: 50px;
  height: 10px;
  background-color: #cecece;
  display: inline-block;
  margin: 5px;
  border-radius: 10px;
}
 
/*给当前的选项点覆盖一个黑色,实现active效果*/
.pic #btn1::before,
.pic #btn2::before,
.pic #btn3::before{
  content: ' ';
  width: 50px;
  height: 10px;
  background-color:rgba(0, 0, 0, 0.6);
  z-index: 2;
  position: absolute;
  opacity: 0;
  transition: all 0.6s;
  border-radius: 10px;
}
#item1:checked~.pic #btn1::before,
#item2:checked~.pic #btn2::before,
#item3:checked~.pic #btn3::before{
  opacity: 1;
  transition: all 0.6s;
}
按下 K 进行搜索