我将整个项目的复习拆分成了几个部分, 每完成一部分我都会提交一次代码, 大家根据所复习到的部分, 检出对应的分支来看代码就可以了, 代码中的注释已经十分详尽了, 有问题或者疑惑大家可以随时留言沟通.
项目地址
知识点汇总
- Alamofire 的基本用法
- Swift-WKWebView
- Swift-归档解档存储自定义类型数据
- Swift中 """ XXX """, 3个双引号的作用
- Swift中 属性类型的区别
- 获取类型的class
- 阻尼动画api
- Kingfisher 的超简单使用方法
- 其他、下载demo运行时的注意事项
5. Swift中 属性类型的区别
5.1 存储型属性: 用于存储一个常量或者变量.说白了就是既能存又能取, 需要开辟内存空间.
5.2 计算型属性: 不直接存储值, 而是通过get / set 来取值或者赋值. 说白了就是执行函数时直接返回其他内存地址; 自己不分配独立空间保存计算结果, 每次执行都会被调用.
6. 获取类型的class
/**
- OC 中获取类型的class
- 不是系统的类: [Person class]
- 是系统的类: NSClassFromString(<#NSString * _Nonnull aClassName#>)
- Swift 中获取类型的class
- 不是系统的类: Person.self
- 是系统的类: NSClassFromString(<#T##aClassName: String##String#>)
*/
7. 阻尼动画api
阻尼动画
8. Kingfisher 的超简单使用方法
为UIImageView 添加extension, 封装Kingfisher
import UIKit
/**
- 目前kf(4.10.1) 提供两种加载网络图片的pai
- kf.setImage(with: <#T##Resource?#>)
- kf.setImage(with: <#T##Resource?#>, placeholder: <#T##Placeholder?#>, options: <#T##KingfisherOptionsInfo?#>, progressBlock: <#T##DownloadProgressBlock?##DownloadProgressBlock?##(Int64, Int64) -> Void#>, completionHandler: <#T##CompletionHandler?##CompletionHandler?##(Image?, NSError?, CacheType, URL?) -> Void#>)
*/
extension UIImageView{
/// 获取网络图片的方法, image传网络图片的地址, placeholder传图片名称
func set_Image(image: String?, placeholder: String? = nil) {
guard let img = image else {
print("图片资源不存在")
return
}
let url = URL(string: img)
guard let u = url else {
print("图像路径转url失败")
return
}
if let p = placeholder {
kf.setImage(with: u, placeholder: UIImage(named: p), options: [], progressBlock: nil, completionHandler: nil)
return
}
kf.setImage(with: u)
}
}
9. 其他、下载demo运行时的注意事项
- 本次代码提交, 完成了未登录、登录、保存用户数据.
逻辑梳理如下:
/**
- 1. 程序启动
- 如果没有登录, 显示访客视图( HTabBarViewController + HVisitorView) -> rootVc = HTabBarViewController()
- 点击登录, 跳转(modal) -> HOAuthViewController(也就是微博的授权webView 登录页面)
- 登陆成功, 发送通知, 跳转至欢迎页面, 切换rootVc = HWelcomeViewController()
- 欢迎页面动画做完, 发送通知 - 跳转至主页(HTabBarViewController - HVisitorView) ->切换 rootVc = HTabBarViewController()
- 已经登录了, 显示欢迎页面, rootVc = HWelcomeViewController()
- 欢迎页面动画做完, 发送通知 - 跳转至主页(HTabBarViewController - HVisitorView) ->切换 rootVc = HTabBarViewController()
*/
首次使用VIewModel, 帮助控制器进行网络请求, 只返回给控制成功与否的结果
当请求是嵌套在一起的时候, 上一个请求的闭包参数需要继续向下传递, 直到最后一个请求成了才算返回true.
- 封装网络工具类HNetworkTools(对Alamofire 的二次封装), 便于后期管理和维护.
下载demo运行时的注意事项
需要去微博开放平台建项、在demo 中HOAuthViewController 更换对应的key.
注: 目前登录可直接点击自动填充来登录, 但这个测试账号随时都有可能失效.最好自己注册一下.
下面教你5分钟都用不上就能注册的流程和配置:
- OAuth授权
- open auth 开放的授权
- 使用微博OAuth授权, 做的是自己的项目, 显示的数据是新浪微博提供的数据
- 如何才可以获取到新浪微博的数据
- 注册一个新浪微博账号
- 登录http://www.open.weibo.com (新浪微博开发者中心)
- 成为开发者
- 个人版
- 企业版 -> 公司
- 在自己的app中使用新浪微博提供的数据
- 添加测试账号(在当前app 没有上架之前只有测试账号才可以拿到新浪微博的数据) 上架以后 只要使用当前app的使用者均可以访问新浪微博的数据
- 登录开发者中心, 完善个人信息, 注册一个应用(微链接 -> 移动应用 -> 立即接入 ->验证成功后,重新打开, 新建应用)
- 选择应用:
- 应用信息 -> 基本信息 ->就会返回一些信息
- APPKEY
- APPSECRECT
- 为我们获取code (授权码) token(访问令牌, 有实效性能)
- 高级信息 -> 手动去设置回调链接
- 测试信息 -> 输入微博用户 ->添加测试用户(之后的登录注册, 获取数据都是使用该测试账号)
- 在我们的app中加载webView (微博授权登录界面)
- 确认授权
- 获取code
- 通过code 获取 token
- 以后请求新浪微博数据 均是通过token 获取到当前账号的微博数据
*/
.End
网友评论