本章内容
1. 创建扩展
注意:这里的containing application指的是,当前的app。
创建完成后将出现下面这个文件夹,对应的是扩展的SB和swift文件。
运行模拟器,就可以看到我们创建的Today了:
2. 扩展和应用之间通信方式一:App Groups
通信原理:利用App Groups这个媒介,容器app和扩展都能访问它。那么,容器app将数据存到App Groups,然后扩展从App Groups里面取出数据,这样产生通信。
缺点:必须加入苹果开发者计划才能使用该功能
-
激活容器app的App Groups
在target-->capability中选择如下图
激活扩展的App Groups
操作步骤跟上面一样,只不过将target选择对应的扩展。容器app将数据存入App Groups
//这种初始化方法专门针对App Groups
//参数为对应app Groups的名称
let userDefault = NSUserDefaults(suiteName: "group.Alet")
userDefault?.setObject("深圳", forKey: "city")
userDefault?.synchronize()
- 扩展从App Groups里面取出数据
let userDefault = NSUserDefaults(suiteName: "group.Alet")
//从App Groups里面获取数据
let cityName: String = userDefault?.objectForKey("city") as! String
//显示在Today上
city.text = cityName
3. 通信方式二:扩展直接调用容器app的API
优点:不用加入苹果开发者计划
原理:将容器app的API用单独的文件封装,使得扩展也能使用这些文件里面的API,通过这些API来获取数据。最好使用framework。
-
创建framework
-
将要封装的swift文件扔进framework的文件夹中
这里要封装的文件是:weatherDataLoad.swift 这个文件里面包含loadData这个类,用来读取数据。
-
将原来target中compile的文件删掉
-
给framework添加需要编译的文件
-
修改framework中文件的访问权限
因为以前的文件的访问权限默认为internal,而要访问framework中的文件,就要设置类的访问权限。
可以根据需求,在文件里面对应的类中设置,如下图。
-
设置扩展能够使用这个framework
最后在扩展的文件中引用这个framework包,就能使用对应的类啦!
其实这样做的目的是:使得容器app和扩展都使用相同的API获取数据,但他们之间互不干扰。