欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐

 更新時間:2019年10月20日 09:34:47   作者:Ly夢k  
這篇文章主要給大家介紹了關(guān)于ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐,文中通過示例代碼介紹的非常詳細(xì),對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

前言

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

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

思路和過程

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

思路一

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

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

思路二

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

思路三

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

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

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對腳本之家的支持。

相關(guān)文章

  • iOS 中 使用UITextField格式化銀行卡號碼的解決方案

    iOS 中 使用UITextField格式化銀行卡號碼的解決方案

    今天小編給大家分享ios中使用UITextField格式化銀行卡號碼的實現(xiàn)思路詳解,非常不錯,具有參考借鑒價值,需要的朋友參考下
    2016-12-12
  • Objective-C實現(xiàn)身份證驗證的方法示例

    Objective-C實現(xiàn)身份證驗證的方法示例

    這篇文章主要給大家分享了Objective-C實現(xiàn)身份證驗證的方法,文中給出了詳細(xì)的示例代碼,對大家具有一定的參考價值,需要的朋友們下面來一起看看吧。
    2017-03-03
  • 如何在iphon IOS設(shè)備上使用二維碼

    如何在iphon IOS設(shè)備上使用二維碼

    深度解析iPhone ios設(shè)備上使用二維碼是本文要介紹的內(nèi)容,二維碼是用某種特定的幾何圖形按一定規(guī)律在平面(二維方向上)分布的黑白相間的圖形記錄數(shù)據(jù)符號信息的。不多說,我們直接來腳本之家學(xué)習(xí)內(nèi)容詳解,感興趣的朋友一起來關(guān)注吧
    2015-08-08
  • iOS性能優(yōu)化淺析

    iOS性能優(yōu)化淺析

    給大家通過理論和經(jīng)驗分析了IOS性能優(yōu)化各方面的問題,以及處理的對應(yīng)辦法,有需要的朋友參考下。
    2018-02-02
  • iOS支付寶、微信、銀聯(lián)支付集成封裝調(diào)用(下)

    iOS支付寶、微信、銀聯(lián)支付集成封裝調(diào)用(下)

    本篇文章通過代碼實例給大家講述了iOS支付寶、微信、銀聯(lián)支付集成封裝調(diào)用,對此有需要的朋友可以測試參考下。
    2018-04-04
  • iOS開發(fā)之手勢識別實例

    iOS開發(fā)之手勢識別實例

    本篇文章主要介紹了iOS開發(fā)之手勢識別實例,具有一定的參考價值,有需要的可以了解一下。
    2016-11-11
  • iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案

    iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案

    這篇文章主要介紹了iOS應(yīng)用開發(fā)中圖片的拉伸問題解決方案,有時圖片的拉伸只需要拉伸中間部分而不拉伸兩端,這是本文所關(guān)注的問題,需要的朋友可以參考下
    2016-02-02
  • iOS客戶端本地推送實現(xiàn)代碼

    iOS客戶端本地推送實現(xiàn)代碼

    這篇文章主要介紹了iOS客戶端本地推送實現(xiàn)代碼,并確定程序中只有一個彈出框,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • iOS實現(xiàn)轉(zhuǎn)場動畫的3種方法示例

    iOS實現(xiàn)轉(zhuǎn)場動畫的3種方法示例

    這篇文章主要給大家介紹了關(guān)于iOS實現(xiàn)轉(zhuǎn)場動畫的3種方法,文中通過示例代碼以及圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • iOS之UITableView計時器的實現(xiàn)方式總結(jié)(NSTimer、DispatchSource、CADisplayLink)

    iOS之UITableView計時器的實現(xiàn)方式總結(jié)(NSTimer、DispatchSource、CADisplayLi

    這篇文章主要給大家介紹了關(guān)于iOS之UITableView計時器的實現(xiàn)方式,其中包括NSTimer、DispatchSource、CADisplayLink等方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2018-12-12

最新評論