iOSScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析

這篇文章主要講解了“iOS ScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“iOS ScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析”吧!

桓仁ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書(shū)未來(lái)市場(chǎng)廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書(shū)銷(xiāo)售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書(shū)合作)期待與您的合作!

前言

隨著業(yè)務(wù)的發(fā)展,頁(yè)面的復(fù)雜度越來(lái)越高,嵌套滾動(dòng)視圖的方式也越來(lái)越受設(shè)計(jì)師們的青睞,在各大電商App十分常見(jiàn)。如下Demo圖:

但是這樣的交互官方并不推薦,而且對(duì)開(kāi)發(fā)來(lái)說(shuō)確是不那么友好,需要處理滾動(dòng)手勢(shì)的沖突,頁(yè)面的多層級(jí)嵌套都給開(kāi)發(fā)帶來(lái)了一定程度的麻煩。接下里我聊聊我們的實(shí)現(xiàn)思路。

思路和過(guò)程

對(duì)應(yīng)這種頁(yè)面結(jié)構(gòu)應(yīng)該毫無(wú)疑問(wèn)是最底層是一個(gè)縱向滾動(dòng)的scrollView,它的頁(yè)面上面放一個(gè)固定高度的header,緊接著下面一個(gè)支持橫向滾動(dòng)切換的容器scrollView,容器上面才是各個(gè)頁(yè)面具體的tableView,如下圖:

思路一

最先想到的是,既然是滾動(dòng)視圖那么我們是否可以通過(guò)滾動(dòng)視圖的可滾動(dòng)屬性來(lái)做呢,在初始時(shí)把最上層具體業(yè)務(wù)的tableView禁止?jié)L動(dòng),那么根據(jù)事件響應(yīng)鏈,滾動(dòng)事件事件會(huì)由底層的ScrollView接收并處理,在到達(dá)最大偏移量之后,禁用底層的ScrollView滾動(dòng),同時(shí)開(kāi)啟上層的tableView,使得上層可以滑動(dòng),想起來(lái)是有一定可行性的,可惜,事實(shí)現(xiàn)實(shí)是殘酷的,效果如下:

這樣會(huì)導(dǎo)致當(dāng)偏移量到達(dá)臨界值時(shí),由于設(shè)置了scrollEnable屬性和最大偏移量,此次滾動(dòng)手勢(shì)會(huì)被截?cái)?,需要再次拖拽才能繼續(xù)滾動(dòng),顯然,這樣的效果是無(wú)法接受的。

思路二

這是同事提供的思路,在做這個(gè)時(shí)和同事有過(guò)討論,他們之前有這樣的交互頁(yè)面,使用的是自定義手勢(shì),但由于UIScrollView是有彈性效果的,一般的滑動(dòng)手勢(shì)做不到這一點(diǎn)的,所以需要引入U(xiǎn)IDynamic模擬力場(chǎng),實(shí)現(xiàn)阻尼效果。想了一下,雖然有一定的可行性,但是為了一個(gè)聯(lián)動(dòng)滑動(dòng),要做這么多的事情,感覺(jué)比較繁瑣,而且自定義手勢(shì)做的模擬彈性效果可能和原生ScrollView的效果還是有一定的差距,所以選擇放棄。

思路三

回到我們思路一,除了邊界位置會(huì)阻斷聯(lián)動(dòng)滾動(dòng)外,其他效果還是可以的,那么能不能通過(guò)手段解決這個(gè)問(wèn)題呢?既然能寫(xiě)到了這里,那么毫無(wú)疑問(wèn),肯定是可以的。通過(guò)手勢(shì)穿透,即讓一個(gè)滑動(dòng)手勢(shì)既作用于底層的ScrollView又能作用于上層的業(yè)務(wù)tableView,同時(shí)控制他們的滾動(dòng)即可達(dá)成目的。通過(guò)讓底層的scrollView實(shí)現(xiàn)一個(gè)手勢(shì)識(shí)別的協(xié)議,同時(shí)響應(yīng)滾動(dòng)事件:

func gestureRecognizer(_ gestureRecognizer: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith otherGestureRecognizer: UIGestureRecognizer) -> Bool { return true }

根據(jù)官方文檔描述:

Asks the delegate if two gesture recognizers should be allowed to recognize gestures simultaneously.

表達(dá)的意思是詢問(wèn)委托是否允許兩個(gè)手勢(shì)識(shí)別器同時(shí)識(shí)別手勢(shì),那么我們實(shí)現(xiàn)這個(gè)協(xié)議,”穿透“手勢(shì),分別在底層容器和上層業(yè)務(wù)中實(shí)現(xiàn)滾動(dòng)視圖的代理方法func scrollViewDidScroll(_ scrollView: UIScrollView),分別控制他們的可滾動(dòng)狀態(tài)和偏移量則能實(shí)現(xiàn)目的。部分實(shí)現(xiàn)如下:

底層容器ScrollView:

func scrollViewDidScroll(_ scrollView: UIScrollView) {  headerView.isHidden = scrollView.contentOffset.y >= maxOffset ? true : false  if !superCanScroll {   scrollView.contentOffset.y = maxOffset   currentVC.childCanScroll = true  } else {   if scrollView.contentOffset.y >= maxOffset {    scrollView.contentOffset.y = maxOffset    superCanScroll = false    currentVC.childCanScroll = true   }  } }

上層業(yè)務(wù)tableView:

func scrollViewDidScroll(_ scrollView: UIScrollView) {  if !childCanScroll {   scrollView.contentOffset.y = 0  } else {   if scrollView.contentOffset.y <= 0 {    childCanScroll = false    superCanScrollBlock?(true)   }  } }

通過(guò)底層ScrollView是否達(dá)到最大偏移量控制header的顯示隱藏和對(duì)應(yīng)的偏移量及可滾動(dòng)狀態(tài),在業(yè)務(wù)tableView使用回調(diào)將ScrollView的可滾動(dòng)狀態(tài)回調(diào)達(dá)到狀態(tài)同步??傮w來(lái)說(shuō)還是比較清晰,更多細(xì)節(jié)請(qǐng)看QFMultipleScrollView

感謝各位的閱讀,以上就是“iOS ScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)iOS ScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

網(wǎng)站標(biāo)題:iOSScrollView嵌套tableView聯(lián)動(dòng)滾動(dòng)的思路分析
網(wǎng)頁(yè)URL:http://www.muchs.cn/article44/jpcdhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、靜態(tài)網(wǎng)站、微信公眾號(hào)、、用戶體驗(yàn)網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作