91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

發布時間:2020-10-13 18:03:39 來源:腳本之家 閱讀:540 作者:chernyog 欄目:移動開發

前言

眾所周知我們大家在開發中,可能會有一些頁面顯示的元素很多,可能會超出一個屏幕,但也不適合用 TableView 或者 CollectionView,此時我們一般會用 ScrollView,那么就會出現自動布局的問題。下面話不多說了,來一起看看詳細的介紹吧。

實現方式

純代碼

  • 特點編碼繁瑣:需要手寫控件
  • 安全:只要正確地設置約束或者 frame、contentSize,一般不會出現滾動問題

示例

lazy var scrollView: UIScrollView = {
 let obj = UIScrollView(frame: CGRect(x: 0, y: 0, width: .screenW, height: self.screenH))
 return obj
}()
override func viewDidLoad() {
 super.viewDidLoad()
 view.addSubview(scrollView)
 let subViewH: CGFloat = 400
 let topView = UIView(frame: CGRect(x: 0, y: 0, width: enW, height: subViewH))
 topView.backgroundColor = UIColor.red
 scrollView.addSubview(topView)
 let bottomView = UIView(frame: CGRect(x: 0, y: subViewH, h: screenW, height: subViewH))
 bottomView.backgroundColor = UIColor.purple
 scrollView.addSubview(bottomView)
 scrollView.contentSize = CGSize(width: screenW, height: iewH * 2)
}

效果圖

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

Storyboard + 內部View

特點

  • 搭建界面簡單
  • 直觀
  • 需要占位視圖

頁面結構如圖

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

可能出現的問題

  • ScrollView 中直接添加子元素,報錯:Has ambiguous scrollable content height
  • ScrollView 內容超出屏幕仍不能滾動

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

實現滾動的代碼

override func viewDidLayoutSubviews() {
 super.viewDidLayoutSubviews()
 let statusBarH: CGFloat = 20
 // 如果沒有導航欄,就返回狀態欄的高度
 let navH = gationController?.navigationBar.frame.maxY ?? statusBarH
 let deltaH = (screenH - navH) - bottomView.frame.maxY
 placeholderViewBottomConstraint.constant = deltaH
}

效果圖

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

Storyboard + 外部View

特點

  • 搭建界面簡單
  • 直觀
  • 不需要占位視圖,不需要對 ScrollView 的布局做特殊處理
  • 需要處理外部視圖的 frame(如果沒有用戶交互,可以忽略)

頁面結構如圖

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

可能出現的問題

  • ScrollView 中直接添加子元素,報錯:Has ambiguous scrollable content height
  • 當內容超出屏幕高度時,必須得設置 ContainerView 的 frame,否則不能滾動或者超出屏幕部分不接受事件

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

實現滾動的代碼

override func viewDidLoad() {
 super.viewDidLoad()
 scrollView.addSubview(containerView)
}
override func viewDidLayoutSubviews() {
 super.viewDidLayoutSubviews()
 var f = containerView.frame
 f.size.width = screenW
 // 這句代碼很重要,處理超出屏幕無法響應事件問題
 f.size.height = bottomView.frame.maxY
 containerView.frame = f
 scrollView.contentSize = CGSize(width: screenW, height: omView.frame.maxY)
}

效果圖

iOS ScrollView實現自動布局的方法(適用Swift 3.0 )

總結

ScrollView 不能滾動的原因

  • contentSize 小于自身 frame 的尺寸
  • isScrollEnabled 屬性,不過它默認就是 true,默認無需設置
  • ScrollView 或者其父元素無法交互,此時我們需要檢查 isUserInteractionEnabled 屬性是否為 true

ScrollView 一直支持滾動

默認情況下,當 ScrollView 里的元素不足一個屏幕高度時,不能滾動,如需滾動(彈簧效果),需要設置 alwaysBounceVertical 屬性為 true(水平方向亦如此)

關于 ScrollView 布局的選擇

純代碼布局

如果是純代碼布局,只能用方式一。老老實實、一行一行代碼實現布局,雖然代碼繁雜,但是坑少。(現在仍有不少公司是這樣編程的)

界面布局

推薦方式三,這樣 ScrollView 和 其子元素分離,可以簡化很多約束問題,更直觀

以上代碼,適用于 Swift 3.0 語法。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

屏南县| 峡江县| 分宜县| 怀仁县| 马关县| 镇巴县| 互助| 邹城市| 丹巴县| 海兴县| 正蓝旗| 克什克腾旗| 黄龙县| 平阴县| 嘉荫县| 山阳县| 孙吴县| 青浦区| 茂名市| 镇康县| 昌图县| 正阳县| 江达县| 阜城县| 任丘市| 辽宁省| 石景山区| 濮阳市| 东源县| 盐津县| 马关县| 岳池县| 镇康县| 莱阳市| 平顺县| 卓尼县| 顺义区| 阳朔县| 饶河县| 华安县| 黎城县|