美文网首页SnapKit 使用
完整Swift项目(模拟微博)演练、三

完整Swift项目(模拟微博)演练、三

作者: 下班不写程序 | 来源:发表于2020-04-03 17:12 被阅读0次

我将整个项目的复习拆分成了几个部分, 每完成一部分我都会提交一次代码, 大家根据所复习到的部分, 检出对应的分支来看代码就可以了, 代码中的注释已经十分详尽了, 有问题或者疑惑大家可以随时留言沟通.
项目地址

知识点汇总

  1. Alamofire 的基本用法
  2. Swift-WKWebView
  3. Swift-归档解档存储自定义类型数据
  4. Swift中 """ XXX """, 3个双引号的作用
  5. Swift中 属性类型的区别
  6. 获取类型的class
  7. 阻尼动画api
  8. Kingfisher 的超简单使用方法
  9. 其他、下载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. 本次代码提交, 完成了未登录、登录、保存用户数据.
    逻辑梳理如下:
/**
- 1. 程序启动
   - 如果没有登录, 显示访客视图( HTabBarViewController + HVisitorView) -> rootVc = HTabBarViewController()
        - 点击登录, 跳转(modal) -> HOAuthViewController(也就是微博的授权webView 登录页面)
        - 登陆成功, 发送通知, 跳转至欢迎页面, 切换rootVc = HWelcomeViewController()
        - 欢迎页面动画做完, 发送通知 - 跳转至主页(HTabBarViewController - HVisitorView) ->切换 rootVc = HTabBarViewController()
   - 已经登录了, 显示欢迎页面, rootVc = HWelcomeViewController()
        - 欢迎页面动画做完, 发送通知 - 跳转至主页(HTabBarViewController - HVisitorView) ->切换 rootVc = HTabBarViewController()
*/
  1. 首次使用VIewModel, 帮助控制器进行网络请求, 只返回给控制成功与否的结果
    当请求是嵌套在一起的时候, 上一个请求的闭包参数需要继续向下传递, 直到最后一个请求成了才算返回true.
  1. 封装网络工具类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

相关文章

网友评论

    本文标题:完整Swift项目(模拟微博)演练、三

    本文链接:https://www.haomeiwen.com/subject/zsbauhtx.html