本文主要讲一下如何用userdefaults在Today Extension和主App间传一些简单数据,传复杂数据的话需要用到资料库,其实大同小异。

众所周知,iOS有沙盒机制,不同App之间无法直接共享数据,Today Extension和主App之间其实就是不同App的关系,所以也无法通过userdefaults.standard来传数据,苹果为了在不打破沙盒的前提下能够传数据,就想出了App Group的方法。

也就是说只要是属于一个组的App,就能互相传数据。

先跟著下图走,添加一下today的小组件:

选Toady Extension,取个名字,我们这里是MyToady

找到主App的Target的Capabilities,把App Groups设为ON

点加号创建一个组,弹出框让我们给这个组取个名字,名字要求是唯一的,所以一般用group+bundle ID就好了

同样找到Toady的Target的App Group这里,选ON,等待几秒钟,就会出现刚刚我们在主App那里创建的App Group,选中这个组。

最后在主App的storyboard上弄一个label,用来待会把里面的文本传给Toady

准备工作完毕,上代码

ViewController:

class ViewController: UIViewController {

//主App上的label
@IBOutlet weak var hostData: UILabel!

//创建一个userdefaults用来共享简单数据(之后的用法和UserDefaults.standard一样)
//这里的name就是刚刚我们创建的App Group的名字
let sharedDefaults = UserDefaults(suiteName: "group.com.rongcosme.TodayTest")

//根据业务逻辑在合适的地方把主App的数据存进sharedDefaults,这里为了演示方便就放在viewDidAppear里
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
sharedDefaults?.set(hostData.text!, forKey: "sharedData")
}
}

TodayViewController:

class TodayViewController: UIViewController, NCWidgetProviding {

//today小组件上的label,用于显示主App传过来的数据
@IBOutlet weak var todayData: UILabel!

//同样是创建一个userdefaults
let sharedDefaults = UserDefaults(suiteName: "group.com.rongcosme.TodayTest")

//一般是在willappear里面,把主App放在UserDefaults里的数据取出来
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)

//这里共享的是string类型的数据,就用string方法
todayData.text = sharedDefaults?.string(forKey: "sharedData")
}

func widgetPerformUpdate(completionHandler: (@escaping (NCUpdateResult) -> Void)) {
completionHandler(NCUpdateResult.newData)
}
}

运行的时候记得选中的是主App

效果:

总结注意点:

1.App Group名字要唯一

2.主App和Toady的App Group都要ON,并且选中同一个组3.注意产生数据的先后顺序,别先取再存,等4.数据的存和取都要在能够执行的代码块里面,不要像IBOutlet那样野在外面5.运行后出现紫色carsh的话,先把主App和Toady都停止掉再运行

以上。

最后打个广告,小弟的iOS视频教程,进阶版也正在制作中:

复昕学堂?

m.study.163.com图标
推荐阅读:

相关文章