视图代码如下,注意我两个tableView设置的坐标,和下面位置对比。
其他有关导航的设置参考:http://blog.csdn.net/riven_wn/article/details/46238255
<span style="font-family:Arial;font-size:18px;"> self.view.backgroundColor = UIColor.whiteColor()
// //设置导航栏透明
// self.navigationController?.navigationBar.setBackgroundImage(UIImage(), forBarMetrics: UIBarMetrics.Default)
// //设置导航栏下部的线不显示
// self.navigationController?.navigationBar.shadowImage = UIImage()
let tableView1 = UITableView()
tableView1.backgroundColor = UIColor.yellowColor()
tableView1.frame = CGRectMake(0, 0, 50, self.view.frame.size.height)
self.view.addSubview(tableView1)
let tableView2 = UITableView()
tableView2.backgroundColor = UIColor.greenColor()
tableView2.frame = CGRectMake(50, 64, 50, self.view.frame.size.height - 64)
self.view.addSubview(tableView2)</span>
self.edgesForExtendedLayout
<span style="font-family:Arial;font-size:18px;">self.edgesForExtendedLayout = .None //扩展 默认.All</span>
iOS7以后
设置 self.edgesForExtendedLayout = .None ,会使tableView的位置下移至导航栏以下,对比图如下:
self.navigationController!.navigationBar.translucent
<span style="font-family:Arial;font-size:18px;">self.navigationController!.navigationBar.translucent = false //半透明 默认true</span>
直接放对比图吧:
self.automaticallyAdjustsScrollViewInsets
<span style="font-family:Arial;font-size:18px;">//automaticallyAdjustsScrollViewInsets:根据按所在界面的status bar,navigationbar,与tabbar的高度,自动调整scrollview的 inset,设置为no,不让viewController调整 默认true
self.automaticallyAdjustsScrollViewInsets = true</span>
注释为网上的说法,这里用iOS9测试的,发现并未影响tableView的位置,对比图:
self.extendedLayoutIncludesOpaqueBars
<span style="font-family:Arial;font-size:18px;">self.extendedLayoutIncludesOpaqueBars = true //默认false</span>
和上一项结果一样。
另:这里有一个疑问,当设置导航栏透明时,设置 self.edgesForExtendedLayout = .None 导航会变成黑条,不解...