【iOS】Storyboard加载Xib自定义view

一直很混淆这种用法,这里记录下来并分享给小白童鞋们

1. 新建DemoView.swift 和 DemoView.xib
【iOS】Storyboard加载Xib自定义view_第1张图片
设置xib显示元素如图
2. 设置xib文件的file's onwer选项
【iOS】Storyboard加载Xib自定义view_第2张图片
设置xib文件的file's onwer
3. 绑定xib中的控件到swift文件中
【iOS】Storyboard加载Xib自定义view_第3张图片
绑定xib中的控件到swift文件中
【iOS】Storyboard加载Xib自定义view_第4张图片
绑定xib控件的事件
4. 在swift文件中实现从xib的初始化加载
// 定义container为DemoView的子view, 以便更方便的封装xib
private var container: UIView!

// 从storyboard上初始化时,会调用该方法
required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        xibSetup()
    }

private func xibSetup() {
        container = Bundle.main.loadNibNamed("DemoView", owner: self, options: nil)?.first as! UIView
        container.frame = bounds
        container.autoresizingMask = [.flexibleWidth, .flexibleHeight]
        addSubview(container)
}
5. 在storyboard上使用
【iOS】Storyboard加载Xib自定义view_第5张图片
storyboard直接使用

这样,基本上写很少的代码,就能实现xib自定义view在任何地方的使用

【iOS】Storyboard加载Xib自定义view_第6张图片
最终效果

【参考】
http://supereasyapps.com/blog/2014/12/15/create-an-ibdesignable-uiview-subclass-with-code-from-an-xib-file-in-xcode-6

你可能感兴趣的:(【iOS】Storyboard加载Xib自定义view)