好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Html5導航欄吸頂方案原理與對比實現

Html5導航欄吸頂方案原理與對比實現

熱門標簽:拓展地圖標注 高德地圖標注地點糾錯 電話機器人黑斑馬免費 南昌仁和怎么申請開通400電話 機器人外呼系統存在哪些能力 電話機器人電銷系統掙話費 只辦理400電話 平涼地圖標注位置怎么弄 如何獲取地圖標注客戶

一. 什么是吸頂?

吸頂效果是web開發中一種常見的交互方式,常見的應用場景有導航、搜索框等等。能夠做流量的橫向分發,矚目的吸頂效果和橫滑切tab的手勢,能夠讓用戶快速發現更多商品。

市場上享有H5導航欄吸頂效果展示

1.淘寶聚劃算吸頂演示:

2.淘寶百億補貼吸頂演示:

 

二. 常見的tabbar吸頂方案

  • 基于position粘性定位的吸頂方案
  • 基于JS監聽scroll事件的吸頂方案

三. 方案的原理與對比

1. position粘性方案的實現與詳解

1.1. 知識詳解

position使我們經常使用的CSS屬性,能夠在布局和解決一些特定問題時候帶來很好的解決方案,例如,卡片的各種icon和標。position粘性定位也是實現吸頂的方案之一,先看看position具有哪些屬性值及相關的含義:

取值 相關解釋
static 該關鍵字指定元素使用正常的布局行為,即元素在文檔常規流中當前的布局位置。此時 top, right, bottom, left 和 z-index 屬性無效。
relative 該關鍵字下,元素先放置在未添加定位時的位置,再在不改變頁面布局的前提下調整元素位置(因此會在此元素未添加定位時所在位置留下空白)。position:relative 對 table-*-group, table-row, table-column, table-cell, table-caption 元素無效。
absolute 元素會被移出正常文檔流,并不為元素預留空間,通過指定元素相對于最近的非 static 定位祖先元素的偏移,來確定元素位置。絕對定位的元素可以設置外邊距(margins),且不會與其他邊距合并。
fixed 元素會被移出正常文檔流,并不為元素預留空間,而是通過指定元素相對于屏幕視口(viewport)的位置來指定元素位置。元素的位置在屏幕滾動時不會改變。打印時,元素會出現在的每頁的固定位置。fixed 屬性會創建新的層疊上下文。當元素祖先的 transform, perspective 或 filter 屬性非 none 時,容器由視口改為該祖先。
sticky 元素根據正常文檔流進行定位,然后相對它的最近滾動祖先(nearest scrolling ancestor)和 containing block (最近塊級祖先 nearest block-level ancestor),包括table-related元素,基于top, right, bottom, 和 left的值進行偏移。偏移值不會影響任何其他元素的位置。

MDN傳送門

關于sticky屬性,顧名思義,單詞sticky的中文意思是“粘性的”,其效果是position:relative和position:fixed的結合。當元素在屏幕內,表現為relative,就要滾出顯示器屏幕的時候,表現為fixed。這個屬性曾經被chrome放棄過,不過后來又得到了支持

<!--示例用法-->
nav{
    position: -webkit-sticky;
    position: sticky;
    top: 0;
}

1.2 兼容性

如上圖所示,position的sticky已經被各類游覽器支持,并且得到了比較好的支持,除safari還需-webkit-前綴支持外。

demo實現:

  *{
        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;
    }
<div class="container">
    <div style="width:100%;height:100px;"></div>
    <div class="nav">position sticky 粘性定位</div>
    <div class="body"></div>
</div>

 

1.3. 可能會踩得坑

  •  使用position:sticky同時,必須同時使用(top、left、right、bottom)中之一,否者無效
  • 父元素不能overflow:hidden或者overflow:auto屬性,否者無效
  • 父元素的高度不能小于sticky元素的高度,否者無效
  • sticky元素僅在其父元素內生效

2. JS監聽scroll事件的吸頂方案

知識詳解 整體思路是通過js對滾動事件的監聽,當滾動到頂部時(距頂部的距離為0時),動態的將元素的position屬性更改為fixed,進行固定定位達到吸頂的效果。 判斷距離頂部的距離比較常規的是使用offsetTop,但offsetTop是相對定位父級的偏移量,倘若需要滾動吸頂的元素出現定位父級元素,那么 offsetTop 獲取的就不是元素距離頁面頂部的距離。這里我們考慮使用 getBoundingClientRect() 獲取頁面中某個元素相對瀏覽器視窗上下左右的距離。 MDN傳送門

function compute(){
    let ele = document.getElementById('nav');
    	if(ele.getBoundingClientRect().top === 1){
    		ele.style.position = "sticky";
    		ele.style.top = 0;
    	}
    }
window.addEventListener('scroll', compute);

到此這篇關于Html5導航欄吸頂方案原理與對比實現的文章就介紹到這了,更多相關Html5 導航欄吸頂內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持腳本之家! 

標簽:西藏 漯河 新疆 青島 永州 池州 遼源 棗莊

巨人網絡通訊聲明:本文標題《Html5導航欄吸頂方案原理與對比實現》,本文關鍵詞  Html5,導航,欄,吸頂,方案,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Html5導航欄吸頂方案原理與對比實現》相關的同類信息!
  • 本頁收集關于Html5導航欄吸頂方案原理與對比實現的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 共夫(总攻NP)海棠| 幼射HD交中国妇| 国内精品久久久久香蕉| 艳乳欲妃潘金莲DVD| 免费无码国产在线看瑜茄| 看一级| 小说(h)| 久久久久久精品一级毛片蜜月| 亚洲AV鲁丝一区二区三区潘金莲| 午夜夫妻视频| a级毛片在线视频免费观看| 和老丈睡觉摸他下身| 深夜yy久久无码国产欧美| 老熟女重囗味HDXX52| 主奴口舌vk| dy888午夜91精品国产| 亚洲一区二区三区二区| 公么又大又粗又硬又爽| 国产精品嫩草影院在线播放| 双腿吊起揉捏花蒂调教h| 国产精品伦人视频免费看三丽医院 | 阿银被爆?3D在线观看| 欲乱高龄老妇小说| 女人和公拘配种女人| 欧美精品电影一区二区| 乱系列140章肉艳1一12| 99精品欧美一区| 色戒在线观看完整版| 静香被吸乳羞羞漫画动漫| 羞羞电影在线观看www| 日韩欧美高清在线观看| 国产秦先生大战白丝97在线 | 久久久久久久久久一级| 女学生和老头做爰A片| 吻胸摸腿揉屁股娇喘视频下载| 91免费国产视频| 91观看视频| 天天夜夜草草久久伊人天堂色窝窝| 学长太粗不行坐不下去| 色黄大色黄女片免费看软件| 特级做A爰片毛片免费69|