MG --Swift扩展

Swift 返回栈中特定的任意控制器(存在于navigationController.children)

extension UIViewController {
    // 查找最合适的响应控制器
    class func currentViewController() -> UIViewController? {
        // Find best view controller
        let viewController: UIViewController? = UIApplication.shared.keyWindow?.rootViewController
        return UIViewController.findBestViewController(viewController)

    }

    class func findBestViewController(_ vc: UIViewController?) -> UIViewController? {
        if vc?.presentedViewController != nil {
            // Return presented view controller
            return UIViewController.findBestViewController(vc?.presentedViewController)
        } else if (vc is UISplitViewController) {
            // Return right hand side
            let svc = vc as? UISplitViewController
            if (svc?.viewControllers.count ?? 0) > 0 {
                return UIViewController.findBestViewController(svc?.viewControllers.last)
            } else {
                return vc
            }
        } else if (vc is UINavigationController) {
            // Return top view
            let svc = vc as? UINavigationController
            if (svc?.viewControllers.count ?? 0) > 0 {
                return UIViewController.findBestViewController(svc?.topViewController)
            } else {
                return vc
            }
        } else if (vc is UITabBarController) {
            // Return visible view
            let svc = vc as? UITabBarController
            if (svc?.viewControllers?.count ?? 0) > 0 {
                return UIViewController.findBestViewController(svc?.selectedViewController)
            } else {
                return vc
            }
        } else {
            // Unknown view controller type, return last child view controller
            return vc
        }
    }
}



/// MARk: - 返回到指定控制器
extension UIViewController {
    /**
     *  导航栏回到指定控制器
     *  className:控制器名字(字符串)
     *  animated:是否带动画
     */
    func back(toController className: String!, animated: Bool) {
        guard let appName: String = Bundle.main.object(forInfoDictionaryKey: "CFBundleName") as? String else {
            return
        }
        let classStringName = appName + "." + className
        guard  let cls:AnyClass = NSClassFromString(classStringName) else {
            return;
        }

        self.back(toControllerClass: cls, animated: animated)
    }

    /**
     *  导航栏回到指定控制器
     *  cls:控制器类名)
     *  animated:是否带动画
     */
    func back(toControllerClass cls: AnyClass, animated: Bool) {
        if navigationController != nil, let childViewControllers = navigationController?.children {
            let resluts = childViewControllers.filter { return $0.isKind(of: cls) }
            if resluts.count>0,let firstObject = resluts.first {
                navigationController!.popToViewController(firstObject, animated: animated)
            }
        }
    }
}
使用截图,调用



Swift 命名空间形式扩展的实现

#if os(macOS)
import AppKit
public typealias Image = NSImage
public typealias View = NSView
public typealias Color = NSColor
public typealias ImageView = NSImageView
public typealias Button = NSButton
#else
import UIKit
public typealias Image = UIImage
public typealias Color = UIColor
#if !os(watchOS)
public typealias ImageView = UIImageView
public typealias View = UIView
public typealias Button = UIButton
#else
import WatchKit
#endif
#endif

// MARK: -
// MARK: - MG
public struct MGNameSpaceWrappable<Base>:MGTypeWrapperProtocol {
    public let base: Base
    init(_ base: Base) {
        self.base = base
    }
}

public protocol MGTypeWrapperProtocol {

}

extension MGTypeWrapperProtocol {
    public var mg: MGNameSpaceWrappable<Self> {
        get {
            return MGNameSpaceWrappable(self)
        }
        set {
            
        }
    }
}

// MARK: -
// MARK: - LYM
public protocol LYMNamespacePotocol {
    associatedtype WrapperType
    var lym: WrapperType { get }
    static var lym: WrapperType.Type { get }
}

public extension LYMNamespacePotocol {
    var lym:  LYMNamespaceWrapper<Self> {
        return  LYMNamespaceWrapper(value: self)
    }

    static var lym:  LYMNamespaceWrapper<Self>.Type {
        return  LYMNamespaceWrapper.self
    }
}

public protocol  LYMTypeWrapperProtocol {
    associatedtype WrappedType
    var wrappedValue: WrappedType { get }
    init(value: WrappedType)
}

public struct  LYMNamespaceWrapper<T>:  LYMTypeWrapperProtocol {
    public let wrappedValue: T
    public init(value: T) {
        self.wrappedValue = value
    }
}
使用截图

调用


关注我

慕课网
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,558评论 4 61
  • 一级标题 二级标题 三级标题 四级标题 五级标题 六级标题 无序列表 文本1 文本2 文本3 有序列表 文本1 文...
    木子里9阅读 207评论 0 1
  • 辰源新起点:新手学习挖掘长尾关键词 一般情况下,网站的80%左右的流量都是来自长尾关键词,特别是综合型门户站,所以...
    cowin1314阅读 375评论 0 0
  • 正文 总是试图将经过的所有事情,刻成回忆,然后全部塞进脑海里,因为怕有一天会忘记。 因此,那些曾经经过的,...
    四平i阅读 366评论 0 1
  • 来河北辛集正好一个月,今天该走了。从刚来时的陌生到现在熟悉再离开,就像生命从出生到成长,最后离去,一个循环。喜欢这...
    星梦一生阅读 329评论 0 2

友情链接更多精彩内容