摘要:希望新版兼容和安卓?jī)啥说那闆r下,無(wú)限制的刷新加載數(shù)據(jù)。圖片大小限制,本次由于部分列表圖片過(guò)大,在安卓上導(dǎo)致黑屏的問(wèn)題出現(xiàn)。
一、背景
近期項(xiàng)目改版,對(duì)原有的h5頁(yè)面進(jìn)行了重新設(shè)計(jì),數(shù)據(jù)呈現(xiàn)變成了瀑布流。希望新版兼容ios和安卓?jī)啥说那闆r下,無(wú)限制的刷新加載數(shù)據(jù)。大致效果如下:
整個(gè)頁(yè)面分4部分:
頂部導(dǎo)航
步數(shù)狀態(tài)卡片
用戶信息卡片
滾動(dòng)列表
期望效果:列表滾動(dòng)到用戶信息卡片消失后,展示另一個(gè)吸頂?shù)膶?dǎo)航欄。
效果如下:
分析可以發(fā)現(xiàn),首先我們要做的就是適配iPhone X,其次我們需要監(jiān)聽列表的滾動(dòng)高度,在pc和安卓上監(jiān)聽滾動(dòng)事件是沒(méi)有問(wèn)題的,但是ios上滾動(dòng)過(guò)程中不會(huì)觸發(fā)scroll事件,而是滾動(dòng)結(jié)束后會(huì)觸發(fā)onscrollend事件,這就不能滿足實(shí)時(shí)監(jiān)聽高度的要求。經(jīng)過(guò)簡(jiǎn)單調(diào)研,決定站在巨人的肩膀上,通過(guò)iscroll、better-scroll等js庫(kù)實(shí)現(xiàn)。這兩個(gè)庫(kù)都是解決各種滾動(dòng)兼容的js庫(kù),很多常見的輪播、picker組件都是基于這些庫(kù)封裝的。順便說(shuō)一句,還有個(gè)庫(kù)也不錯(cuò)(simulation-scroll-y)
1.適配iPhone X
PhoneX的適配,在iOS 11中采用了viewport-fit的meta標(biāo)簽作為適配方案;viewport-fit的默認(rèn)值是auto。react app的渲染內(nèi)容都在id為root的 div里面。我們給這個(gè)div加上iphoneX的safe-area-inset屬性即可。更多相關(guān)內(nèi)容,這篇文章寫的挺詳細(xì)
#root{ height:100vh; padding-top: constant(safe-area-inset-top); padding-left: constant(safe-area-inset-left); padding-right: constant(safe-area-inset-right); padding-bottom: constant(safe-area-inset-bottom); padding-top: env(safe-area-inset-top); padding-left: env(safe-area-inset-left); padding-right: env(safe-area-inset-right); padding-bottom: env(safe-area-inset-bottom); }
2.頁(yè)面
頁(yè)面結(jié)構(gòu)不多說(shuō),比較基礎(chǔ)。
div.container-> div#wrapper->div.list->div.list-item
值得注意的是,wrapper需要設(shè)置絕對(duì)定位。同時(shí),通過(guò)transform: translateZ(0);開啟硬件加速,瀏覽器在渲染時(shí)會(huì)通過(guò)GPU進(jìn)行渲染。有效緩解安卓端滾動(dòng)卡頓的問(wèn)題,類似的css還有不少,css硬件加速不要濫用,否則會(huì)導(dǎo)致不該使用gpu的layer使用gpu,占用內(nèi)存過(guò)高,導(dǎo)致頁(yè)面卡頓,甚至黑屏,一般情況下,給不同的硬件加速元素添加一個(gè)不同的z-index屬性可以解決。-webkit-overflow-scrolling: touch使ios滾動(dòng)順滑。
// 初始化BScroll偽代碼,生產(chǎn)慎用:
import BScroll from "better-scroll"; this.myScroll = new BScroll("#wrapper", { mouseWheel : true, // 無(wú)需scrollbar scrollbar : false, // propType屬性設(shè)置為3在慣性動(dòng)畫期間也觸發(fā)onscroll事件 probeType : 3, // 允許滾動(dòng)列表內(nèi)可點(diǎn)擊、touch click : true, tap : true, // 上拉加載,正值自動(dòng)觸發(fā)加載 pullUpLoad : { threshold: 50 } });
一開始,我將better-scroll初始化代碼放在container組件的componentDidMount函數(shù)中,但由于初始數(shù)據(jù)也在這個(gè)函數(shù)獲取,導(dǎo)致當(dāng)返回較慢的時(shí)候初始化的#wrapper沒(méi)有內(nèi)容,此時(shí)需要手動(dòng)點(diǎn)擊加載更多才展現(xiàn)數(shù)據(jù),不符合預(yù)期。所以考慮將初始化代碼放到list組件渲染完成之后的componentDidUpdate函數(shù)中。list組件渲染完成后,就可以初始化我們的滾動(dòng)類,這里使用的better-scroll,iscroll使用類似。具體參考上面鏈接。
#wrapper { position:absolute; top:0; left:0; width:100vw; overflow:auto; height: 100vh; transform: translateZ(0); z-index: 33; -webkit-overflow-scrolling: touch }
具體的,可以將初始化代碼放在list組建的container組件的handleScrollRefresh函數(shù)。這個(gè)函數(shù)作為props傳到list組件,在list組件的componentDidUpdate鉤子里面執(zhí)行:
container組件:
handleScrollRefresh () { if (this.myScroll) { this.myScroll.refresh(); console.log("refreshed "); } else { console.log("initialized"); this.myScroll = new BScroll("#wrapper", { ...//初始化參數(shù) }); this.myScroll.on("scroll",this.handleScroll, 10); this.myScroll.on("pullingUp", this.loadMore); } }
list 組件:
componentDidUpdate () { if (this.props.onRefresh) { this.props.onRefresh(); } }
網(wǎng)上很多滾動(dòng)卡頓的情況,大都是加載數(shù)據(jù)后沒(méi)有執(zhí)行refresh導(dǎo)致的。同時(shí),加載數(shù)據(jù)成功后我們需要調(diào)用scroll的finishPullUp方法。下次上拉才能繼續(xù)加載數(shù)據(jù)。這樣,每當(dāng)加載新的數(shù)據(jù)后,list組件就會(huì)執(zhí)行componentDidUpdate,此時(shí)就調(diào)用了scroll的finishPullUp、refresh函數(shù),使用起來(lái)無(wú)比順滑。
三、優(yōu)化
和大多數(shù)滾動(dòng)處理一樣,better-scroll的scroll事件也會(huì)頻繁觸發(fā),這對(duì)性能還是有一定影響的,畢竟我們不需要過(guò)于頻繁的執(zhí)行回調(diào)函數(shù)。
throttle (func, delay) { let lastTime = null; return function () { let context = this; let args = arguments; let now = new Date().getTime(); if (!lastTime || (now - lastTime) > delay) { lastTime = now; func.apply(context, args); } }; };
不想寫直接使用lodash也可以:
//不精準(zhǔn)的每秒十次 this.myScroll.on("scroll", this.throttle(this.handleScroll, 100));
函數(shù)綁定,不傳參的情況下在constructor中綁定this。而不是在render中使用this.xxx.bind(this)。
list 圖片大小限制,本次由于部分列表item圖片過(guò)大,在安卓上導(dǎo)致黑屏的問(wèn)題出現(xiàn)。排查了很久才發(fā)現(xiàn)這個(gè)問(wèn)題。通過(guò)在圖片url拼接參數(shù)限制大小解決了這個(gè)問(wèn)題。
最后感覺(jué)寫得好亂,做事情和寫文章果然是兩回事。。。
有興趣可以訪問(wèn):https://3hours.taobao.com/new...
一起來(lái)做公益吧!
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/108858.html
摘要:比如安卓平臺(tái)在中不能觸屏手動(dòng)滾動(dòng)。主要的功能界面模塊大部分主要是展示的,網(wǎng)易云的頁(yè)面和功能實(shí)在是太多了,由于時(shí)間關(guān)系,并沒(méi)有把所有的功能都做完整,后續(xù)會(huì)陸續(xù)加上其他的功能。各部分模塊首頁(yè)展示音樂(lè)播放,包括動(dòng)畫,歌詞同步等。 React Native 模仿網(wǎng)易云音樂(lè)手機(jī)客戶端,兼容安卓和IOS兩個(gè)平臺(tái)。 GitHub 完整源碼地址https://github.com/yezihaohao...
摘要:最近在使用技術(shù)棧重構(gòu)一個(gè)單頁(yè)應(yīng)用,其中有個(gè)頁(yè)面是實(shí)現(xiàn)城市選擇功能,主要是根據(jù)城市的首字母來(lái)快速跳轉(zhuǎn)到相應(yīng)位置,比較類似原生中的電話聯(lián)系人查找功能,頁(yè)面如圖主要問(wèn)題在上下滑動(dòng)右側(cè)定位的元素時(shí),頁(yè)面會(huì)跟著一起滑動(dòng)當(dāng)然這個(gè)現(xiàn)象在開發(fā)過(guò)程中應(yīng)該會(huì)經(jīng) 最近在使用 React 技術(shù)棧重構(gòu)一個(gè)單頁(yè)應(yīng)用,其中有個(gè)頁(yè)面是實(shí)現(xiàn)城市選擇功能,主要是根據(jù)城市的首字母來(lái)快速跳轉(zhuǎn)到相應(yīng)位置,比較類似原生 APP ...
摘要:主要有兩種方式和。的私有標(biāo)簽,頂端狀態(tài)條的樣式。禁止數(shù)字自動(dòng)識(shí)別為電話號(hào)碼,這個(gè)比較有用,因?yàn)橐淮當(dāng)?shù)字在上會(huì)顯示成藍(lán)色,樣式加成別的顏色也是不生效的。頁(yè)面禁止復(fù)制選中文本 react 移動(dòng)端 兼容性問(wèn)題和一些小細(xì)節(jié) 使用 ES6 的瀏覽器兼容性問(wèn)題 react 對(duì)低版本的安卓webview 兼容性 iOS下 fixed與軟鍵盤的問(wèn)題 onClick 阻止冒泡 meta對(duì)于移動(dòng)端的一些...
摘要:主要有兩種方式和。的私有標(biāo)簽,頂端狀態(tài)條的樣式。禁止數(shù)字自動(dòng)識(shí)別為電話號(hào)碼,這個(gè)比較有用,因?yàn)橐淮當(dāng)?shù)字在上會(huì)顯示成藍(lán)色,樣式加成別的顏色也是不生效的。頁(yè)面禁止復(fù)制選中文本 react 移動(dòng)端 兼容性問(wèn)題和一些小細(xì)節(jié) 使用 ES6 的瀏覽器兼容性問(wèn)題 react 對(duì)低版本的安卓webview 兼容性 iOS下 fixed與軟鍵盤的問(wèn)題 onClick 阻止冒泡 meta對(duì)于移動(dòng)端的一些...
閱讀 3444·2021-09-26 09:46
閱讀 2792·2021-09-13 10:23
閱讀 3532·2021-09-07 10:24
閱讀 2400·2019-08-29 13:20
閱讀 2926·2019-08-28 17:57
閱讀 3080·2019-08-26 13:27
閱讀 1186·2019-08-26 12:09
閱讀 513·2019-08-26 10:27