利用锚点的思想能够实现一个简单的选项卡切换效果。
页面布局及样式:浏览器
<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 的上 边缘和滚动容器上边缘对齐,从而实现选项卡效果。布局
可是这种方式有必定的不足之处:学习
为了改变这种状况,下面利用下面的方式。页面布局为:spa
<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 行为,触发锚点定位,实现选项卡切换效果。code
可是上面这种技术要想用在实际项目中还离不开JavaScript 的支持,一个是选项卡按钮的选中效果,另外一个就是处理列表部分区域在浏览器外面时依然会跳动的问题。
相关处理相似下面的作法,使用 jQuery 语法:blog
$('label.click').removeAttr('for').on('click', function() { $('.box').scrollTop(xxx); 'xxx'表示滚动数值 });
学习总结于张鑫旭老师的CSS世界第6章three