CSS实现简单的选项卡切换效果(附代码)


本文摘自PHP中文网,作者不言,侵删。

本篇文章给大家带来的内容是关于CSS实现简单的选项卡切换效果(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

利用锚点的思想可以实现一个简单的选项卡切换效果。

页面布局及样式:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<div class="box">

  <div class="list" id="one">1</div>

  <div class="list" id="two">2</div>

  <div class="list" id="three">3</div>

  <div class="list" id="four">4</div>

</div>

<div class="link">

  <a href="#one">1</a>

  <a href="#two">2</a>

  <a href="#three">3</a>

  <a href="#four">4</a>

</div>

 

......

 

.box {

   height: 10em;

   border: 1px solid #ddd;

   overflow: hidden;

}

.list {

   line-height: 10em;

   background: #ddd;

}

容器设置了 overflow:hidden,且每个列表高度和容器的高度一样高,这样保证永远 只显示一个列表。当我们点击按钮,如第三个按钮,会改变 URL 地址的锚链为#three,从 而触发 id 为 three 的第三个列表发生的锚点定位,也就是改变容器滚动高度让列表 3 的上 边缘和滚动容器上边缘对齐,从而实现选项卡效果。

3372313660-5bfce3b04c4e2_articlex.png

但是这种方式有一定的不足之处:

  • 其一,容器高度需要固定;

  • 其二,锚点定位会触发窗体的重定位,也就是如果页面可以滚动,那么点击选项页面也会发生跳动

为了改变这种情况,下面利用下面的方式。页面布局为:

1

2

3

4

5

6

7

8

9

10

11

12

<div class="box">

    <div class="list"><input id="one">1</div>

    <div class="list"><input id="two">2</div>

    <div class="list"><input id="three">3</div>

    <div class="list"><input id="four">4</div>

</div>

<div class="link">

    <label class="click" for="one">1</label>

    <label class="click" for="two">2</label>

    <label class="click" for="three">3</label>

    <label class="click" for="four">4</label>

</div>

这样写就算页面窗体就有滚动条,绝大多数情况下,也都不会发生跳动现象。其原理就是在每个列表里塞入一个肉眼看不见的<input>输入框,然后选项卡按钮变成<label>元素,并通过 for 属性与<input>输入框的 id 相关联,这样,点击选项按钮会触发输入框的 focus 行为,触发锚点定位,实现选项卡切换效果。

但是上面这种技术要想用在实际项目中还离不开JavaScript 的支持,一个是选项卡按钮的选中效果,另一个就是处理列表部分区域在浏览器外面时依然会跳动的问题。
相关处理类似下面的做法,使用 jQuery 语法:

1

2

$('label.click').removeAttr('for').on('click', function() { $('.box').scrollTop(xxx); 'xxx'表示滚动数值

});

以上就是CSS实现简单的选项卡切换效果(附代码)的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

css如何解决高度不一致问题

外联css怎么写

css怎么设置文件编码

css怎么让div隐藏

css什么时候用padding

css的语法结构是什么?

jquery怎么改变css样式

css设置背景图大小该怎么做

如何选择web前端模板引擎(推荐)

css什么时候清除浮动

更多相关阅读请进入《css》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    暂无评论...