将xib分配给Swift中的UIView

Siu*_*han 58 xib uiview swift

在目标c中,它可以在init方法中完成

-(id)init{
    self = [[[NSBundle mainBundle] loadNibNamed:@"ViewBtnWishList" owner:0 options:nil]     objectAtIndex:0];
return self;
}
Run Code Online (Sandbox Code Playgroud)

但是当我快速地这样做时

init(frame: CGRect) {
    self = NSBundle.mainBundle().loadNibNamed("ViewDetailMenu", owner: 0, options: nil)[0] as? UIView
}
Run Code Online (Sandbox Code Playgroud)

无法在方法中分配给self自己显示错误.现在我的方法是创建一个视图,并将从nib加载的视图添加到它.谁都有更好的主意?

dre*_*wag 126

对于Swift 4

extension UIView {
    class func loadFromNibNamed(nibNamed: String, bundle: Bundle? = nil) -> UIView? {
      return UINib(
          nibName: nibNamed,
          bundle: bundle
      ).instantiate(withOwner: nil, options: nil)[0] as? UIView
  }
}
Run Code Online (Sandbox Code Playgroud)

对于Swift 3

你可以在UIView上创建一个扩展:

extension UIView {
    class func loadFromNibNamed(nibNamed: String, bundle: NSBundle? = nil) -> UIView? {
        return UINib(
            nibName: nibNamed,
            bundle: bundle
        ).instantiateWithOwner(nil, options: nil)[0] as? UIView
    }
}
Run Code Online (Sandbox Code Playgroud)

注意:使用UINib更快,因为它会为您进行缓存.

然后你可以这样做:

ViewDetailItem.loadFromNibNamed("ViewBtnWishList")
Run Code Online (Sandbox Code Playgroud)

并且您将能够在任何视图上重用该方法.

  • 如果我在包含其他视图的布局中使用它,我会遇到问题,然后我将出口设置为类,我收到“由于未捕获的异常“NSUnknownKeyException”而终止应用程序,原因:“[<NSObject 0x17000bae0> setValue: forUndefinedKey:]:该类不符合键 infoView 的键值编码。'` (3认同)
  • 谢谢,所以我可以创建自定义uiview如下?var customView = ViewDetailItem.loadFromNibNamed("ViewBtnWishList")但是如果我想在创建自定义视图时初始化一些更多的变量呢?在这种情况下,我们是否绕过了UIView的init方法? (2认同)

kar*_*agu 24

在Xcode 7 beta 4,Swift 2.0中测试过.以下代码将xib分配给UIView.您可以在故事板中使用此自定义xib视图并访问该IBOutlet对象.

import UIKit

@IBDesignable class SimpleCustomView:UIView
{
    var view:UIView!;

    @IBOutlet weak var lblTitle: UILabel!

   @IBInspectable var lblTitleText : String?
        {
        get{
            return lblTitle.text;
        }
        set(lblTitleText)
        {
            lblTitle.text = lblTitleText!;
        }
    }

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

    required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        loadViewFromNib ()
    }
    func loadViewFromNib() {
        let bundle = NSBundle(forClass: self.dynamicType)
        let nib = UINib(nibName: "SimpleCustomView", bundle: bundle)
        let view = nib.instantiateWithOwner(self, options: nil)[0] as! UIView
        view.frame = bounds
        view.autoresizingMask = [.FlexibleWidth, .FlexibleHeight]
        self.addSubview(view);



    }


}
Run Code Online (Sandbox Code Playgroud)

以编程方式访问customview

self.customView =  SimpleCustomView(frame: CGRectMake(100, 100, 200, 200))
        self.view.addSubview(self.customView!);
Run Code Online (Sandbox Code Playgroud)

源代码 - https://github.com/karthikprabhuA/CustomXIBSwift

  • 也可以在其他XIB中使用 - 这很棒.但是 - 一个问题是,这不是直接从XIB创建自定义视图.它正在从XIB加载UIView并将其作为子视图添加到自定义视图中. (3认同)

Dav*_*ave 23

这对我有用.

override func awakeAfterUsingCoder(aDecoder: NSCoder) -> AnyObject? {
    if self.subviews.count == 0 {
        return loadNib()
    }
    return self
}

private func loadNib() -> YourCustomView {
    return NSBundle.mainBundle().loadNibNamed("YourCustomViewNibName", owner: nil, options: nil)[0] as YourCustomView
}
Run Code Online (Sandbox Code Playgroud)

  • 这是在storyboard或xib文件中重用的最佳解决方案.如果只是将加载的nib视图添加为子视图,则不能正确设置委托等属性 (2认同)

hol*_*lex 17

这可能是你的解决方案:

Swift 3.x

class func instanceFromNib() -> UIView {
    return UINib(nibName: "<<NibFileName>>", bundle: nil).instantiate(withOwner: nil, options: nil)[0] as! UIView
}
Run Code Online (Sandbox Code Playgroud)

Swift 2.x

class func instanceFromNib() -> UIView {
    return UINib(nibName: "<<NibFileName>>", bundle: nil).instantiateWithOwner(nil, options: nil)[0] as UIView
}
Run Code Online (Sandbox Code Playgroud)