成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JS解決position:sticky的兼容性問題

helloworldcoding / 1809人閱讀

摘要:解決的兼容性問題在項(xiàng)目中有用到的布局,可是由于兼容性問題,在安卓端沒有很好的兼容,所以為了徹底解決這個(gè)問題只能寫一個(gè)組件來解決這個(gè)麻煩的問題,這里為什么是組件而不是指令是因?yàn)椋怯性虻?,下面?huì)講到。

JS解決position:sticky的兼容性問題

在項(xiàng)目中有用到sticky的布局,可是由于兼容性問題,在安卓端沒有很好的兼容,所以為了徹底解決這個(gè)問題只能寫一個(gè)組件來解決這個(gè)麻煩的問題,這里為什么是組件而不是指令是因?yàn)?,是有原因的,下面?huì)講到。

position:sticky的兼容性以及作用

Caniuse上顯示sticky的兼容性如下:

Sticky的作用相當(dāng)于relative和fixed的結(jié)合體,當(dāng)修飾的目標(biāo)節(jié)點(diǎn)再屏幕中時(shí)表現(xiàn)為relative,當(dāng)要超出的時(shí)候是fixed的形式展現(xiàn),因?yàn)檫@個(gè)特性,我們就可以來實(shí)現(xiàn)一個(gè)sticky的模擬效果。

sticky組件實(shí)現(xiàn) template部分

代碼解讀:這里我使用了組件來實(shí)現(xiàn),而不用指令來實(shí)現(xiàn)的原因是:指令雖然是無侵入性的,更方便使用,可是有一個(gè)弊端就是當(dāng)修飾的節(jié)點(diǎn)fixed的時(shí)候會(huì)脫離文檔流,會(huì)改變滾動(dòng)的條的高度,如果僅僅是配合原生滾動(dòng)條來實(shí)現(xiàn)是沒問題的(當(dāng)然這也會(huì)存在滾動(dòng)過快的問題),可是由于是配合自定義滾動(dòng)所以,采取這種折中的方式來實(shí)現(xiàn)。最外層是一個(gè)sticky層,判斷瀏覽器是否支持sticky,不支持就使用relative來代替,這樣也就不會(huì)改變?yōu)g覽器高度的情況了,然后動(dòng)態(tài)改變stick-warp層的postion來實(shí)現(xiàn)效果。

css部分

代碼解讀:這里的warp層的背景色設(shè)置和sticky一致,這樣過渡不會(huì)太生硬,高度和top都根據(jù)用戶對(duì)外層sticky的自定義來實(shí)現(xiàn),這樣這部分簡單用css就可以完成了。

JS部分

代碼解讀:這里面主要先用cssSupport來判斷一下瀏覽器的支持情況,然后通過多自定義滾動(dòng)y-scroll事件的監(jiān)聽,監(jiān)聽top值的改變來實(shí)現(xiàn)sticky-warp層的fixed和absolute的轉(zhuǎn)換。大概原理的思路及實(shí)現(xiàn)過程就是上面這樣,對(duì)于自定義的滾動(dòng)的github地址:https://github.com/yejiaming/scroll,sticky組件以及原生滾動(dòng)下的指令參考的實(shí)現(xiàn)的github地址如下:https://github.com/yejiaming/sticky

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/89124.html

相關(guān)文章

  • 解決頁面滾動(dòng)時(shí)吸頂操作不能及時(shí)響應(yīng)bug

    摘要:這個(gè)界限就是該元素頂部距離窗口頂部的距離等于該元素設(shè)置的值比如以下像素分割線當(dāng)我的頂部距離窗口頂部為值時(shí),我就會(huì)像一樣在距離窗口值處的時(shí)代發(fā)送分效果圖當(dāng)頁面滾動(dòng)到距離黃色區(qū)塊頂部時(shí),黃色區(qū)塊就會(huì)在窗口頂部處,頁面再往下滾動(dòng)距離也不會(huì)變。 position: sticky; fixed 吸頂 頁面滾動(dòng)結(jié)束后頁面才渲染 需求 經(jīng)常會(huì)有這樣的需求,當(dāng)頁面滾動(dòng)到某一個(gè)位置fixedTopV...

    gaomysion 評(píng)論0 收藏0
  • 解決頁面滾動(dòng)時(shí)吸頂操作不能及時(shí)響應(yīng)bug

    摘要:這個(gè)界限就是該元素頂部距離窗口頂部的距離等于該元素設(shè)置的值比如以下像素分割線當(dāng)我的頂部距離窗口頂部為值時(shí),我就會(huì)像一樣在距離窗口值處的時(shí)代發(fā)送分效果圖當(dāng)頁面滾動(dòng)到距離黃色區(qū)塊頂部時(shí),黃色區(qū)塊就會(huì)在窗口頂部處,頁面再往下滾動(dòng)距離也不會(huì)變。 position: sticky; fixed 吸頂 頁面滾動(dòng)結(jié)束后頁面才渲染 需求 經(jīng)常會(huì)有這樣的需求,當(dāng)頁面滾動(dòng)到某一個(gè)位置fixedTopV...

    wapeyang 評(píng)論0 收藏0
  • 解決頁面滾動(dòng)時(shí)吸頂操作不能及時(shí)響應(yīng)bug

    摘要:這個(gè)界限就是該元素頂部距離窗口頂部的距離等于該元素設(shè)置的值比如以下像素分割線當(dāng)我的頂部距離窗口頂部為值時(shí),我就會(huì)像一樣在距離窗口值處的時(shí)代發(fā)送分效果圖當(dāng)頁面滾動(dòng)到距離黃色區(qū)塊頂部時(shí),黃色區(qū)塊就會(huì)在窗口頂部處,頁面再往下滾動(dòng)距離也不會(huì)變。 position: sticky; fixed 吸頂 頁面滾動(dòng)結(jié)束后頁面才渲染 需求 經(jīng)常會(huì)有這樣的需求,當(dāng)頁面滾動(dòng)到某一個(gè)位置fixedTopV...

    gggggggbong 評(píng)論0 收藏0
  • WEB移動(dòng)端粘黏吸頂效果解決方案

    摘要:原文鏈接一般的吸頂,通常是給上一個(gè)定位便可實(shí)現(xiàn),而類似于上圖這樣的粘黏吸頂,也是一個(gè)比較常見的需求粘黏吸頂大概的思路是這樣首先,給吸頂欄一個(gè)或者定位,通過去監(jiān)聽事件觸發(fā)一個(gè)判斷吸頂欄高度的函數(shù),當(dāng)吸頂欄的高度距離可視區(qū)域頂部小于等于時(shí),將其 原文鏈接: Fyerls Blog showImg(https://segmentfault.com/img/bVJMAs?w=360&h=240...

    macg0406 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<