iOS开发功能Debug

iOS开发中“xib”与“纯代码”取舍

2020-03-13  本文已影响0人  M_PI_4

一. 知名app的xib与纯代码使用情况

讨论的是:对于 UI 界面的编写工作,到底应该用 xib/storyboard 完成,还是用手写代码来完成?有一些著名的应用,它们也用到了xib

1. 像 Twitter,Mailbox,objcio 这样完全不使用 xib 做界面的情况。
2. 像 QQ、微信、滴滴打车、网易新闻、猿题库这样少量使用 xib 的情况。
3. 像支付宝、大众点评这样重度使用 xib 的情况。
说明了即使是比较著名的 App,在使用 xib/storyboard 上,也有很大的差异。

有兴趣的伙伴也可以自己使用“tangqiao”的脚本(科学一下才好打开)分析一下

其实,我们实际开发中一些简单界面的开发,我们使用xib就足够了,速度快、产出也高效。但是,我们在处理一些UI比较复杂的页面,我们使用纯代码来进行开发,在迭代和修改方面更方便,所以建议复杂的开发还是用纯代码。

二. 考虑因素

1.开发效率

纯代码编写,界面越复杂,代码量越大,复杂度也随之上升。
使用xib,可以把界面布局相关的代码,属性设置的代码,迁移到xib上,修改了什么马上可以看到效果,所见即所得,界面开发速度快很多;使用xib中的autolayout,屏幕尺寸适配也方便得多。

2.可读性

代码越多,别人读起来越费劲,使用xib,界面层的代码大量减少,可读性极好。

3.复用

纯代码可复用,xib比较难复用,有相同或相似界面,基本是复制一份过来修改,复用问题不大。

4.版本管理

代码的版本管理比较清晰成熟,大家也用得比较顺。xib因为其为xml格式文件,可读性比较差,多人同时修改同一个xib文件时会引起冲突,并且难以合并。所以,做好一个或一系列相关界面使用一个xib,避免多人同时修改一个xib引起冲突。

5.性能

纯代码的界面加载速度、运行速度是最快的,xib会稍微拉低性能,消耗更多内存,但这对多数普通界面来说,没有太大影响。需要极致的性能和速度的界面,才使用纯代码。
不管是纯代码还是xib,autolayout都不宜使用过多,超过60个,会引起卡顿。

三. 优劣

使用 xib 和 storyboard 的优点

使用 xib 和 storyboard 的缺点

纯代码的优点

纯代码的缺点

总结:

从以往开发经验,我觉得代码+xib实现App界面,大大提高开发效率、可读性,版本管理的缺陷避免即可。现在App开发已经很成熟,企业开发基本会追求好看的界面效果、更复杂的界面布局,用纯代码实现,代码复杂度急剧加大,极有必要通过xib简化界面代码。另外,企业开发中,版本更新频繁、需求变化多,采用xib才能更快更好的响应这些变化。

参考链接


上一篇 下一篇

猜你喜欢

热点阅读