
public class Book { var Title: String? var date: NSDate?} 由于我需要访问属性的几个不同的类,我使用反射来运行类的属性:
let myBook = Book()myBook.Title = "Hello"myBook.date = NSDate()let mirror = Mirror(reflecting: myBook)var propsArr = [(key: String?,value: Any)]()let mirrorChildrenCollection = AnyRandomAccessCollection(mirror.children)!if mirrorChildrenCollection.count > 0 { propsArr += mirrorChildrenCollection}//iterate through propertIEsfor case let (label?,value) in propsArr { print (label,value) if let val = value as? NSDate { var extractedDate = val print(extractedDate) } else if let val = value as? String { var extractedTitle = val print (extractedTitle) }} 但我有一个问题,即Child对象没有被提取,因为它们是Type Any和内部可选类,因此不属于我的情况.如果我从String更改标题?对于String,它们确实有效,但我需要使用可选类型.
在上面的实现中我可以更改什么以将数据类型保留为String?和日期?并仍然从镜像中提取值?
解决方法 看来这在Swift 2.x中是不可能的.由于属性是可选项,您必须转换为NSDate?和String ?,分别如下:
if let val = value as? NSDate? { // val is Optional<NSDate>} 不幸的是,编译器不允许这样做(我不确定为什么)://错误:无法从’protocol<>‘转发更可选的类型’NSDate?’.
bubuxu从bubuxu提供了一个聪明的解决方法,如果您为每个属性都有一个镜像,它将起作用.镜像的displayStyle属性告诉您它是否是可选的,然后您可以手动提取包装的值.这样可行:
let child = Mirror(reflecting: myBook.date)child.displayStyleif child.displayStyle == .Optional { if child.children.count == 0 { // .None } else { // .some let (_,some) = child.children.first! if let val = some as? NSDate { print(val) } }} 但这取决于为每个属性设置一个镜像,并且似乎你无法遍历镜像的子节点来为它们检索镜像.
总结以上是内存溢出为你收集整理的如何从Swift中的Mirror子类中提取可选的类型值?全部内容,希望文章能够帮你解决如何从Swift中的Mirror子类中提取可选的类型值?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)