加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Swift下自定义xib添加到Storyboard

发布时间:2020-12-14 06:55:02 所属栏目:百科 来源:网络整理
导读:猴子原创,欢迎转载。转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://www.jb51.cc/article/p-vcfowvhx-vb.html 我们使用Storyboard布局的时候,很多子单元页面会独立到xib布局中,那么这个xib如何添加到storyboard中呢?下面我们看看Swift下怎

猴子原创,欢迎转载。转载请注明: 转载自Cocos2Der-CSDN,谢谢!
原文地址: http://www.52php.cn/article/p-vcfowvhx-vb.html

我们使用Storyboard布局的时候,很多子单元页面会独立到xib布局中,那么这个xib如何添加到storyboard中呢?下面我们看看Swift下怎么操作。


一、准备工作

  1. 新建Xcode工程
  2. 新建一个UIView:MyView.swift 集成自UIView
  3. 新建一个UIView的xib布局文件:MyView.xib
    这个是我MyView.xib内容:

二、互相关联MyView.xib与MyView.swift

xib关联到MyView.swift

  1. 设置MyView.xib的File’s Owner 的Custom Class为MyView
  2. 注意:不要修改MyView.xib下View的Custom Class,保存其为默认的UIView。

MyView.swift设置

  1. 将MyView.xib下的View拖拽到MyView.swift中关联IBOutlet属性变量:view
@IBOutlet var view: UIView!
  1. 添加初始化代码在MyView.swift中:
required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)

        // app 运行后从storyboard加载
        NSBundle.mainBundle().loadNibNamed(
            String(MyView),owner: self,options: nil
            )[0] as! UIView
        self.addSubview(view)
        view.frame = self.bounds

        self.setup()
    }

    func setup() {
        // init code ...
    }

三、添加MyView.xib到Main.storyboard

  1. 拖拽一个UIView到Main.storyboard中,设置该UIView的Custom Class为MyView,添加一下布局约束。

OK,现在运行Xcode,是不是看到app运行后,自己的xib已经出来了。


四、让Xcode下Main.storyboard中预览xib

细心的朋友注意到了,Main.storyboard中没有刷新xib视图,只能运行后才能看到,下面我们让Main.storyboard中也能预览xib。
1. 添加@IBDesignable属性
2. 添加Main.storyboard下xib初始化方法
3. 注意:
- Xcode非运行状态下storyboard加载xib使用NSBundle.mainBundle().loadNibNamed会出现找不到xib文件的错误。
- xib加载后,需要设置其frame大小,不然frame会是xib中的大小。
- 每次选中storyboard,都会自动Build一次来刷新其中xib视图,如果过程中出现错误信息可以直接Xcode下查看,如果出现Crash错误,Xcode下不会显示,此时去查看下面的crash文件来帮助你定位问题。

~/Library/Logs/DiagnosticReports/IBDesignablesxxxxxxx.crash

下面是完整MyView.swift

import UIKit

@IBDesignable class MyView: UIView {

    @IBOutlet var view: UIView!

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)

        // app 运行后从storyboard加载
        NSBundle.mainBundle().loadNibNamed(
            String(MyView),options: nil
            )[0] as! UIView
        self.addSubview(view)
        view.frame = self.bounds

        self.setup()
    }

    override init(frame: CGRect) {
        super.init(frame: frame)

        // Xcode中storyboard预览加载
        NSBundle(forClass: MyView.self).loadNibNamed(
            String(MyView),options: nil
            )[0] as! UIView
        self.addSubview(view)
        view.frame = self.bounds

        self.setup()
    }

    func setup() {
        // init code ...
    }

    @IBAction func tapped(sender: AnyObject) {
        print("tappd")
    }
}

效果图:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读