一直很混淆这种用法,这里记录下来并分享给小白童鞋们
1. 新建DemoView.swift 和 DemoView.xib
data:image/s3,"s3://crabby-images/8502d/8502d4099e54e00390eeeb94c751d244129ff6db" alt=""
2. 设置xib文件的file's onwer选项
data:image/s3,"s3://crabby-images/6456f/6456fa88801ea9d7d95f8af851b3f72789e3972c" alt=""
3. 绑定xib中的控件到swift文件中
data:image/s3,"s3://crabby-images/32d2e/32d2e3c99653d6577cb2b2ed2084110b9963cba6" alt=""
data:image/s3,"s3://crabby-images/36b1d/36b1d7661fb3799b871bbe5448f8b470f5833acb" alt=""
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上使用
data:image/s3,"s3://crabby-images/3da08/3da08e7098b17b5c05a40d0d51b53a663bb82151" alt=""
这样,基本上写很少的代码,就能实现xib自定义view在任何地方的使用
data:image/s3,"s3://crabby-images/f7737/f77379a1cb8166dc791b7bc550996468585a9f1e" alt=""
网友评论