技术头条(投递你的文章)     搜索本站     邮件订阅     微信号:IT技术博客大学习
您现在的位置首页 --> iOS开发 --> iOS可视化编程 Tips 之“消灭重复又无聊的代码之 UITableView 篇”

iOS可视化编程 Tips 之“消灭重复又无聊的代码之 UITableView 篇”

浏览:213次  出处信息

   今天继续分享“可视化编程 Tips”系列文章。今天的主题是消灭重复又无聊的代码。

省去设置代理为自己的代码

   我们经常会遇到这样的需求:一个普通的页面,顶部是一些固定的信息,不可滚动。下面是一个 Table View,可以滚动。在这个时候,没法使用 UITableViewController,我们就需要手动添加一个 UITableView,类似下图的样子:

   pic

   然后我们需要让当前的 View Controller 去实现 UITableViewDelegate 和 UITableViewDataSource 这两个协议和那几个必须实现的方法了,然后我们就要写那两行无聊代码了:

self.tableView.delegate = self
self.tableView.dataSource = self

   这两行代码写到 viewDidLoad() 里会显得那么的突兀和多余,他们在不同的类里面也不需要不同的配置,可以说完全是没必要写的代码嘛。而通过对 StoryBoard 的可视化操作,我们可以轻易地省去这两行代码:

   pic

   pic

省去隐藏空白行的代码

   然后,我们就遇到了另一个非常普遍的需求:页面数据不足以沾满整个屏幕时,后面的空白行不再显示。

   一般大家都是这么做的:

self.tableView.tableFooterView = UIView()

不只是节省一行代码,还可以让程序更健壮

   这样做一般都能解决问题,但是这么做有一个副作用:执行这句话时,Table View 会刷新一次,不仅浪费计算资源,而且如果数据源初始化的代码不小心放到了后面,将会直接引发奔溃。

   我们通过可视化的简单操作就可以避免上面可能出现的问题。无论这个 Table View 里面的 cell 将是直接用 StoryBoard 里的还是另从 xib 来初始化,我们都直接给此 Table View 放入一个 cell 用来占位,然后再在 cell 下面放入一个同级的空 view:

   pic

能够处理不同的 UI 需求

   之后根据需要调整这个 view 的高度为 0 或 1。

   默认状态:

   pic

   高度为零时:

   pic

   高度为 1 时,最后一行的间隔线被覆盖了:

   pic

额外的强大功能

   pic

   如果你接到了一个这样的 UI 设计图,要求在 Table View 的底部加上一个固定高度的特殊视图。如果用 Table View Cell 来做,不仅做起来相对麻烦,而且还要选择定高方式、处理触摸事件、传递当前 View Controller 对象等一些非常不必要的额外工作。

   如果采用上文所展示的方式去做,就简单许多了:底部的 View 固定在 Table View 的底部,高度固定,不参与 cell 触摸事件,无需重绘,无需传递当前 View Controller 对象,内部完全支持 Auto Layout,基本上跟一个普通 子 View 没有任何的区别,可以直接绑定元素到当前 View Controller 的成员变量,非常好用。

觉得文章有用?立即: 和朋友一起 共学习 共进步!

建议继续学习:

  1. 好软件推荐 gnuplot 来做可视化数据    (阅读:2240)
  2. 给数据穿上美丽的外衣    (阅读:2009)
  3. 惊现!表面下的隐藏信息――浅谈信息可视化    (阅读:1943)
  4. 白话Block Formatting Context    (阅读:1408)
  5. 浅谈信息可视化――航空篇    (阅读:1302)
  6. 浅析来源分析的数据可视化    (阅读:1299)
  7. 数据可视化初体验(R语言)    (阅读:1042)
  8. 一种基于flex的可视化多层流量切分界面的实现    (阅读:1008)
  9. 轻触,数据美丽的外衣    (阅读:936)
  10. 信息可视化研究范畴及案例    (阅读:849)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2017 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号