How iOS UITableView under NavigationBar?

后端 未结 5 1296
渐次进展
渐次进展 2021-01-11 15:17

I have set

NavigationController.NavigationBar.Translucent = true;

Then add table and set frame to RootView Frame, and:

             


        
5条回答
  •  無奈伤痛
    2021-01-11 15:53

    Solutions that introduce a magic constant don't scale most of the time. For example, if the next iPhone introduces a different navigation bar height we'll have to update our code.

    Fortunately, Apple provided us cleaner ways of overcoming this issue, for example topLayoutGuide:

    The topLayoutGuide property comes into play when a view controller is frontmost onscreen. It indicates the highest vertical extent for content that you don't want to appear behind a translucent or transparent UIKit bar (such as a status or navigation bar)

    Programmatically you can achieve with the following code snippet (the same can be achieved via IB too):

    override func viewDidLoad() {
      super.viewDidLoad()
    
      automaticallyAdjustsScrollViewInsets = false
      tableView.translatesAutoresizingMaskIntoConstraints = false
      NSLayoutConstraint.activate([
        tableView.leadingAnchor.constraint(equalTo: view.leadingAnchor),
        tableView.trailingAnchor.constraint(equalTo: view.trailingAnchor),
        tableView.topAnchor.constraint(equalTo: 
           topLayoutGuide.bottomAnchor),
        tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor)
      ])
    }
    

    Note: topLayoutGuide is deprecated on iOS 11, we should use the safeAreaLayoutGuide property of UIView instead.

提交回复
热议问题