您好,登錄后才能下訂單哦!
這篇文章主要講解了“怎么用微信小程序中scroll-view實(shí)現(xiàn)錨點(diǎn)滑動(dòng)”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“怎么用微信小程序中scroll-view實(shí)現(xiàn)錨點(diǎn)滑動(dòng)”吧!
示意圖如下:
因?yàn)樵谖⑿判〕绦虻沫h(huán)境中不能想在瀏覽器里設(shè)置標(biāo)簽,或者操作dom滾動(dòng),傳統(tǒng)做法就行不通了,一切都得按小程序的文檔來。
一開始我們的做法是使用boundingClientRect()方法獲取每個(gè)錨點(diǎn)的坐標(biāo),然后再用wx.pageScrollTo()方法滑動(dòng)過去。結(jié)果發(fā)現(xiàn)效果不是很好,因?yàn)閎oundingClientRect方法返回的每個(gè)點(diǎn)的坐標(biāo)會(huì)隨著屏幕滑動(dòng)而變化,可能還會(huì)引起頁(yè)面抖動(dòng),最后還是選擇scroll-view(可滾動(dòng)視圖區(qū)域)組件來實(shí)現(xiàn)錨點(diǎn)效果。
具體實(shí)現(xiàn)
具體API就不贅述了,可以去看官方文檔,這里講幾個(gè)需要注意的地方,下面是一個(gè)示意的scroll-view組件代碼,上面的幾個(gè)屬性是必須的:
復(fù)制代碼 代碼如下:
<scroll-view scroll-y bindscroll="scroll" scroll-into-view="{{toView}}" >
scroll-into-view:這個(gè)綁定了一個(gè)屬性,它的值應(yīng)該是頁(yè)面元素的id,設(shè)置它的值就可以跳轉(zhuǎn)到ID對(duì)應(yīng)的元素那里了。
scroll-y:添加這個(gè)屬性標(biāo)明是豎向滑動(dòng)的,對(duì)應(yīng)的scroll-x則表示橫向滑動(dòng),豎向滑動(dòng)時(shí)scroll-view必須設(shè)置一個(gè)固定的height
bindscroll:監(jiān)聽滑動(dòng),傳給他一個(gè)事件,滑動(dòng)時(shí)執(zhí)行該事件
文檔上給的屬性特別多,暫時(shí)只需要上述幾個(gè)就可實(shí)現(xiàn)我們想要的效果。實(shí)現(xiàn)原理也很簡(jiǎn)單,內(nèi)容部分,每個(gè)英文簡(jiǎn)寫的view設(shè)置一個(gè)id,然后在導(dǎo)航list那里點(diǎn)擊時(shí),就把scroll-into-view的值設(shè)置成點(diǎn)擊的那個(gè)id即可實(shí)現(xiàn)跳轉(zhuǎn)。
再說一下scroll-view的高度問題,這個(gè)一定要做適配的固定高度,不然在不同屏幕大小的手機(jī)上的顯示效果有差異。
幾點(diǎn)優(yōu)化
到這里功能基本都實(shí)現(xiàn)了,但后面還發(fā)現(xiàn)一些問題:如果要隱藏scroll-view的滾動(dòng)條,需要設(shè)置css樣式:::-webkit-scrollbar
::-webkit-scrollbar { width: 0; height: 0; color: transparent; }
還有就是點(diǎn)了一個(gè)錨點(diǎn)實(shí)現(xiàn)了跳轉(zhuǎn),這個(gè)時(shí)候你滾動(dòng)頁(yè)面再點(diǎn)之前點(diǎn)的錨點(diǎn),頁(yè)面就不會(huì)再跳轉(zhuǎn)了,這個(gè)時(shí)候就需要監(jiān)聽滾動(dòng)事件,滾動(dòng)時(shí)將scroll-into-view屬性的值清空?;蛘咴诿看五^點(diǎn)跳轉(zhuǎn)后,再由一個(gè)異步操作將scroll-into-view屬性的值清空。
感謝各位的閱讀,以上就是“怎么用微信小程序中scroll-view實(shí)現(xiàn)錨點(diǎn)滑動(dòng)”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)怎么用微信小程序中scroll-view實(shí)現(xiàn)錨點(diǎn)滑動(dòng)這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。