新聞中心
一. 什么是吸頂?
吸頂效果是web開(kāi)發(fā)中一種常見(jiàn)的交互方式,常見(jiàn)的應(yīng)用場(chǎng)景有導(dǎo)航、搜索框等等。能夠做流量的橫向分發(fā),矚目的吸頂效果和橫滑切tab的手勢(shì),能夠讓用戶(hù)快速發(fā)現(xiàn)更多商品。

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了灌南免費(fèi)建站歡迎大家使用!
市場(chǎng)上現(xiàn)有H5導(dǎo)航欄吸頂效果展示
1.淘寶聚劃算吸頂演示:
2.淘寶百億補(bǔ)貼吸頂演示:
二. 常見(jiàn)的tabbar吸頂方案
- 基于position粘性定位的吸頂方案
- 基于JS監(jiān)聽(tīng)scroll事件的吸頂方案
三. 方案的原理與對(duì)比
1. position粘性方案的實(shí)現(xiàn)與詳解
1.1. 知識(shí)詳解
position使我們經(jīng)常使用的CSS屬性,能夠在布局和解決一些特定問(wèn)題時(shí)候帶來(lái)很好的解決方案,例如,卡片的各種icon圖標(biāo)。position粘性定位也是實(shí)現(xiàn)吸頂?shù)姆桨钢唬瓤纯磒osition具有哪些屬性值及相關(guān)的含義:
MDN傳送門(mén)
關(guān)于sticky屬性,顧名思義,單詞sticky的中文意思是“粘性的”,其效果是position:relative和position:fixed的結(jié)合。當(dāng)元素在屏幕內(nèi),表現(xiàn)為relative,就要滾出顯示器屏幕的時(shí)候,表現(xiàn)為fixed。這個(gè)屬性曾經(jīng)被chrome放棄過(guò),不過(guò)后來(lái)又得到了支持
- nav{
- position: -webkit-sticky;
- position: sticky;
- top:
1.2 兼容性
如上圖所示,position的sticky已經(jīng)被各類(lèi)游覽器支持,并且得到了比較好的支持,除safari還需-webkit-前綴支持外。
demo實(shí)現(xiàn):
- *{
- padding:0;
- margin:0;
- }
- .container{
- width:100%;
- background:rgba(0,0,0,.5);
- }
- .nav{
- width:100%;
- height:50px;
- text-align: center;
- line-height: 50px;
- background: black;
- color:white;
- position: sticky;
- top:0;
- }
- .body{
- width:100%;
- height:10000px;
- }
position sticky 粘性定位
1.3. 可能會(huì)踩得坑
- 使用position:sticky同時(shí),必須同時(shí)使用(top、left、right、bottom)中之一,否者無(wú)效
- 父元素不能overflow:hidden或者overflow:auto屬性,否者無(wú)效
- 父元素的高度不能小于sticky元素的高度,否者無(wú)效
- sticky元素僅在其父元素內(nèi)生效
2. JS監(jiān)聽(tīng)scroll事件的吸頂方案
知識(shí)詳解 整體思路是通過(guò)js對(duì)滾動(dòng)事件的監(jiān)聽(tīng),當(dāng)滾動(dòng)到頂部時(shí)(距頂部的距離為0時(shí)),動(dòng)態(tài)的將元素的position屬性更改為fixed,進(jìn)行固定定位達(dá)到吸頂?shù)男Ч?。判斷距離頂部的距離比較常規(guī)的是使用offsetTop,但offsetTop是相對(duì)定位父級(jí)的偏移量,倘若需要滾動(dòng)吸頂?shù)脑爻霈F(xiàn)定位父級(jí)元素,那么 offsetTop 獲取的就不是元素距離頁(yè)面頂部的距離。這里我們考慮使用getBoundingClientRect()獲取頁(yè)面中某個(gè)元素相對(duì)瀏覽器視窗上下左右的距離。 MDN傳送門(mén)
- function compute(){
- let ele = document.getElementById('nav');
- if(ele.getBoundingClientRect().top === 1){
- ele.style.position = "sticky";
- ele.style.top = 0;
- }
- }
- window.addEventListener('scroll', compute);
四. 總結(jié)
永遠(yuǎn)不存在最好的技術(shù)或者技術(shù)方案,只存在當(dāng)前業(yè)務(wù)下的最佳技術(shù)和方案。
名稱(chēng)欄目:一篇帶給你H5吸頂方案
瀏覽地址:http://m.fisionsoft.com.cn/article/dhjdgch.html


咨詢(xún)
建站咨詢(xún)
