在互联网上关于Interface Builder的争吵每天都在发生,用和不用大家都有一大堆的理由。最近看了这篇文章,很多地方和作者有共鸣,结合自己的一些经历,就有了你现在所看到的东西,你可以把它当成前者的中文版。

一年前我开始做iOS开发,看的是Stanford的CS 193P。老头子推荐新手用Storyboard来做开发,因为它是可视化的,不太需要了解代码层的东西就能拖出界面,各种配置项可以通过勾选搞定,省去很多代码,相当傻瓜,此外Storyboard也让人对应用程序的活动流程一目了然。我对这种拖拽式的编程方式很不习惯:这不是代码出奇迹的节奏啊!

我开始做实际的项目。看了几个开源项目的代码后,我知道旧时代有个xib格式的文件。这货是Interface Builder的产物,现在我们称他们为NIB。用法和Storyboard差不多,可视化拖拽、配置。Storyboard比较新,业界用的人不多,于是我很纠结,到底是听老头子的话用新东西,还是随大流试试单独的NIB?初生牛犊不怕虎,反正没怎么做过iOS开发,就按课上说的来吧,我们团队用Storyboard拖UI。一个月后,我提议弃用Interface Builder,不用任何NIB(包括Storyboard)。直到现在只要是在我控制范围内,我都没再碰过任何NIB,我更愿意用代码来生成。

不用Interface Builder的理由很多,对我来说主要有一下几点:

多人协作

从项目管理的角度来讲NIB就不应该被使用。你能保证自己从来不会在合并NIB时出现冲突吗?在一个稍有规模,多开发者的项目里,合并NIB简直就是梦魇。特别是多人共用一个Storyboard时,开发者将花费很多时间和精力去解决冲突,而不是去做比这更有意义的事。

当然,如果最终合并结果正确可信,那么很多同学还是可以忍受的。然而,合并毕竟是会出问题的,尤其是用Git自动合并。这些问题直到运行时才会出现!倘使测试力度不够,这就是潜在的隐患。此外,我们知道NIB是人不可读的,也就是说,对它做版本控制几乎没有意义。你没法从diff看出来半点名堂。倘使你使用的不是NIB,而是一行一行的Objective-C代码,那么结果会好很多。

选择显式而非隐式

我喜欢用代码来完成各种东西,这样你打开一个view或者一个view controller,就能看到所有东西。否则,看你代码的这位同学还得去找相应的NIB。

NIB同样也是滋生bug的温床,很多时候你调试了半天才发现,某个bug并不是出在自己的代码里,而是在Interface Builder的某个小角落里自己忘记给某个选项打上√。如果所有的组件都由代码生成,那么在调试时就简单得多,你只要专注于和View有关的代码就快好了。选择显式地在代码里写view,可以让你对view有强大的控制力。从初始化到布局、绘制你都能插手,在代码里你清楚地知道某个view的各个属性会是多少,而非交由Interface Builder来管理,这样虽然看上去代码行数多了,但它帮你减少了bug数量,节省了debug时间。

耦合

用Interface Builder去创建可复用的view会是一件很蛋疼的事。首先你需要拖拽出各种各样的组件,然后给每个组件设置属性,接着你要把outlet连接到要用到的代码块……某一次,你忘记连outlet,然后你的程序就在runtime crash了。看,你又弄出了一堆bug。对于各种零碎的view我更喜欢为他们写类,然后在里面实现各种我想要的东西,在需要用到这些view的时候生成对象就是了。如果我有什么错误,编译器大哥还能帮我检查。

使用NIB让我提心吊胆,它让程序变得不那么紧凑。很多需要内聚的东西,被分了出去。从实际的开发体验来讲就是东一块,西一块,切来切去我都觉得烦。一旦当你定制的view越来越多,NIB就增多,然后呵呵。

布局

我承认自己几乎没在Interface Builder用过各种layout(包括auto-layout)。我不清楚用NIB做layout是否困难。但我知道重写UIViewlayoutSubviews让布局变得很简单。所有子元素的布局只要在这里设置就行了。需要重新布局时,调一下setNeedsLayout就行。不用关心什么Interface Builder里各种layout概念,不用把布局代码分地方写(降低耦合)。只要稍加判断,让同一个view适应iPhone和iPad不是什么难事。给iPad和iPhone分别提供NIB这种事简直不能忍。

本地化

当IB遇到本地化会发生什么呢?我屮艸芔茻!只要涉及本地化的NIB,都要你去投时间和体力做啊。点鼠标啊,设置啊,纯体力活!如果用代码,字符串用NSLocalizedString(@"Localizable String", @"Comment"),然后在资源文件里翻译一下,轻轻松松。

小结

Interface Builder的初衷可能是希望帮助开发者节省写界面的时间和精力。可视化,表现层和数据分离都是很好的思想。但它在目前还不让人满意。它让多人协作变得困难,诱导拙劣的实践,降低可复用性,让你开发变慢……

我如果能不用IB,就不用,作为一名程序员更应该用代码说话。从装逼角度来讲,这样才显得高端大气上档次不是吗?

转:http://blog.xianqu.org/2013/06/why-i-dont-use-interface-builder/

iOS杂谈-我为什么不用Interface builder的更多相关文章

  1. iOS开发工具Xcode:Interface Builder

    简介: Interface Builder(IB)是Mac OS X平台下用于设计和测试用户界面(GUI)的应用程序(非开源).为了生成GUI,IB并不是必需的,实际上Mac OS X下所有的用户界面 ...

  2. iOS 8 Auto Layout界面自动布局系列2-使用Xcode的Interface Builder添加布局约束

    http://blog.csdn.net/pucker/article/details/41843511 上一篇文章<iOS 8界面自动布局系列-1>简要介绍了iOS界面布局方式的前世今生 ...

  3. 【转 iOS 8 Auto Layout界面自动布局系列2-使用Xcode的Interface Builder添加布局约束

    原文网址:http://blog.csdn.net/pucker/article/details/41843511 上一篇文章<iOS 8界面自动布局系列-1>简要介绍了iOS界面布局方式 ...

  4. IOS 使用Interface Builder开发界面入门与技巧

    引言: 通过Interface Builder(简称IB)来制作界面一直是iOS开发界饱受争议的方式.主要争议的话题是不太适合团队协作开发,再就是对IB的使用比较生疏,觉得IB只能完成一些很简单的功能 ...

  5. iOS开发-Interface Builder的前世今生

    Interface Builder,是用于苹果公司Mac OS X操作系统的软件开发程序,Xcode套件的一部分,于1988年创立.它的创造者Jean-Marie Hullot自称是“一个热爱旅行.充 ...

  6. Interface Builder: What are the UIView's Layout iOS 6/7 Deltas for?

    up vote57down votefavorite 19 I just noticed the iOS 6/7 Delta property found under the UIView's str ...

  7. iOS开发~interface Builder(简称 IB) 界面构建器

    1.interface Builder 设置界面 1.1 是什么? 一个可视化的界面编辑工具软件,在xcode4之后整合到了xcode中 1.2 作用? 通过可视化的界面设置,能够少写或不写代码而完成 ...

  8. iOS学习笔记(1)--认识Xcode6.1的Interface Builder和常用快捷键

    Interface Builder基本界面 红色区域为工具栏(Tool Bar) 蓝色区域为导航区(Navigator Area) 绿色区域为编辑区(Editor Area) 黑色区域是调试区(Deb ...

  9. 【iOS】Interface Builder 预览

    Interface Builder 为最顶层视图提供了 Simulated Metrics,预览用户界面的各种外观设置效果,例如顶部有导航栏或底部有标签栏的效果,如图所示:

随机推荐

  1. tomcat 协议之并发协议 Http11NioProtocol

    关于此协议的原理是什么尚不明确,待后续学习,但是该协议(Http11NioProtocol)能够改善高并发时tomcat的性能. 默认为HTTP/1.1,也就是阻塞式,在改用org.apache.co ...

  2. 《Linux内核设计与实现》读书笔记(十七)- 设备与模块

    本章主要讨论与linux的设备驱动和设备管理的相关的4个内核成分,设备类型,模块,内核对象,sysfs. 主要内容: 设备类型 内核模块 内核对象 sysfs 总结 1. 设备类型 linux中主要由 ...

  3. 设计模式->观察者模式

    观察者模式能非常大的减少模块之前的耦合.具体的观察者模式,客官们可以去看<设计模式>或者<Head first设计模式>等之类的书. 在java中,java.util库中封装了 ...

  4. Entity Framework 4 数据事务操作

    利用数据库链接进行事务操作 var db = ConnectionHelper.GetConn(ConnectionType.Write);//获取上下文 var conn = db.Connecti ...

  5. 使用 Aspose.Slide 获取PPT中的所有幻灯片的标题

    本文使用的是第三方类库 Aspose.Slide,如果你使用的是OpenXml可以看下面的链接,原理是相同的,这个文章里也有对Xml标签的详细解释. 如何:获取演示文稿中的所有幻灯片的标题 原理: 原 ...

  6. Http Status 参考

    http://tool.oschina.net/commons?type=5 状态码 含义 100 客户端应当继续发送请求.这个临时响应是用来通知客户端它的部分请求已经被服务器接收,且仍未被拒绝.客户 ...

  7. 解读SQL 内存数据库的细节

    相信大家对内存数据库的 概念并不陌生,之前园子里也有多位大牛介绍过SQL内存数据库的创建方法,我曾仔细 拜读过,有了大致了解,不过仍有很多细节不清晰,比如: (1)内存数据库是把整个数据库放到内存中的 ...

  8. [WinAPI] API 4 [注册][创建][消息][第一个框架类窗口]

    首先注册了窗口类,然后创建了一个窗口,创建窗口时指定的窗口的属性和窗口消息的处理函数.函数消息的处理函数大多调用系统默认函数来处理. #include<windows.h> /*全局变量* ...

  9. EF Code First Migration总结

    开启Migration 1. 通过 Tools->Nuget Package Manager->Package Manager Console 打开Package Manager Cons ...

  10. js语法

    需要<script language="javascript">标签: ||或者:二选一,满足为true.,否则为false &&与:同时满足,即为tr ...