前言
- 在开发过程中,我们经常会遇到同一个界面需要在多个场景中使用,但是每个场景却又是针对原始界面进行一些细微变化的情况,这个时候,我们可以采用多个.xib文件复用同一个xxxxViewController.swift文件,其实直接创建多个控制器文件既具有可读性也简单,这里看着更加的复杂了,我也不知道为什么会有这个操作,但是在原始项目中看到了这个用法,就把他记录下来,也算是增加一种新的可能吧;
- 该方法同样适用于跨target类的调用,但是需要一些细节上的注意,后面我会详细说明。
构筑首个xxxViewController(带xib)
1.首先我们像往常一样创建一个ViewController;
2.针对该控制器区分出通用部分以及单独使用部分
这里我标注了通用部分和基础版,这个通用部分就是后续多个xib文件中都需要展示的UI控件,而基础版则是只会在该xib文件中使用。
拷贝原始xib文件
1.由于是对基础界面进行的修改,所以我们直接对原始界面xib进行拷贝;
2.将拷贝后的文件重命名并拖拽进项目,这里需要注意的是,如果是跨target调用的情况,需要在Add to targets中勾选对应的target类别,否则调用时将报错,推荐命名法直接在后面加上 ".xxxx"来区分,这里我使用的是BasicVC.Buyer.xib 与 BasicVC.Seller.xib来命名
关联拷贝xib的对应控件
1.针对拷贝后的xib单独拖拽对应的控件,通用的文本依旧使用同一个@IBOutlet 进行关联,这里使用的是名为lbCommon的UI控件,而单独使用的重新拖拽@IBOutlet,由于使用的是weak修饰符,在实现的过程中,总是从xib指向代码块来检索,所以并不用担心代码中遇到xib中不存在的@IBOutlet时会报错,但需要注意的是默认拖拽生成的UI参数会对该弱引用进行强制转换,为了不引起后续在代码中操作失误导致强制转换控制而引起的报错,我们可以将非通用的部分改为可选类型?,例如UILabel?
2.对于跨target调用的情况,还需要另外在target Membership中勾选出关联的xib所属的对应target,否则依旧会报错
自此所有xib层面所需要完成的工作就结束了
代码层面调用
// 代码中绑定对应xib的方法
// 由于这里使用的是跨target的情况,所以通过标识来进行区分调用,实际使用中可自行区分
func create() -> UIViewController {
var nibName: String?
#if Buyer
nibName = "BasicVC.Buyer"
#elseif Seller
nibName = "BasicVC.Seller"
#else
nibName = "BasicVC"
#endif
// 根据对应的xib名进行加载
let vc = BasicVC(nibName: nibName, bundle: nil)
return vc
}