用枚举简化登录操作

今天的内容翻译自Simplifying Login with Swift Enums,隐隐约约的记得好像有人翻译过这篇内容,我本来对这篇内容不是很感兴趣,但无意中发现了另外一篇博文指出:《Simplifying Login with Swift Enums》这么做并不好,所以我的兴趣就来了,我准备把两篇内容都整理一下,今天先发这一篇。首先要推荐大家看原文,我这里并没有逐句的对照翻译,我是按照自己的理解重新把内容整理了一遍。如果有出现不正确的地方欢迎大家留言给我。

原作者David East根据自己的经验得出一个结论:一款app在登录操作上,如果想获得用户的信任和好评,那么需要为用户提供选择,提供多种登陆方式。David East认为swift的枚举可以有效的对登录逻辑进行抽象,从而令我们能够保持view controllers的干净简洁。我自己确认为这篇内容做为enum的基本介绍是比较合适的。

使用枚举定义社交账号登录

enum LoginProvider {
  case Facebook
  case Email
  case Google
  case Twitter
}

很多语言的枚举只是出于类型安全的考虑而把普通类型打个包而已,而swift中的枚举则是一个实实在在的 first-class,枚举中每一个case都是一个fully-fledged value,例如:Facebook 的类型就是LoginProvider。

枚举的Raw Values

我们可以给枚举的每一个case存储一个值,我们把这种值称作枚举的Raw Values。

enum LoginProvider: String {
  case Facebook = "facebook"
  case Email = "email"
  case Google = "google"
  case Twitter = "twitter"
}

对于Raw Values我们应该关注几件事情:

  • Raw Values要求枚举的定义是有明确的返回类型,我们这里是 String
  • 枚举的每个case的类型必须是一致的
  • 我们可以通过rawValue来初始化一个枚举,参数名称就是rawValue
let provider = LoginProvider.init(rawValue: "email")

通过定义的rawValue “email”,我们可以获得一个 Email,这个确实很方便。

Associated Values

rawValue实际上是给枚举的每个case做了一个常量的预设值,那我们可不可以给每个case绑定一个变量值呢?这样的话我们就可以非常方便的给以枚举根据特定情况绑定不同的值了。幸运的是,swift确实提供这个能力:Associated Values

enum LoginProvider {
  case Facebook
  case Email(String, String)
  case Google
  case Twitter
}

let provider = LoginProvider.Email("bob@bob.com", "pass")

关于Associated Values我们可以关注几件事情:

  • 每个case的类型可以不同,各自根据各自的需要使用类型
  • 枚举的定义上面没有返回值了
  • Associated Values可以是任意类型

我们可以定义一个user类型,然后作为枚举的Associated Values。

struct LoginUser {
  let email: String
  let password: String
  func isValid() -> Bool {
    return email != "" && password != ""
  }
}


enum LoginProvider {
  case Facebook
  case Email(LoginUser)
  case Google
  case Twitter
}

有了这样的定义之后,我们就可以创建一个Email枚举了.

let provider = LoginProvider.Email(user)

在Associated Values特性的帮助下,枚举可以“渗透到”各种问题的解决方案中去,而不会因为关联类型问题而被拒之门外。

case where

原作者说:正是因为有Associated Values特性的存在,才显得case where特别的甜。

let provider = LoginProvider.Email(user)

switch provider {
  case let .Email(user) where user.isValid():
    // login!
    break
  case let .Email(user) where !user.isValid():
    // don’t login!
    break
}

case let 首先对Email进行了值绑定(把user对象抽出来),然后使用使用where关键字引入的条件表达式,对逻辑进行了一步处理。switch与枚举的配合确实相当完美(和Tuples也类似)。

Functions

说case where还只是一个铺垫,毕竟我们是在这里赞美枚举吗,switch再好也不是枚举的内容啊。无需感到遗憾,枚举内可以定义function,可以整合所有你需要的内容。

enum LoginProvider {
    case Facebook
    case Email(LoginUser)
    case Google
    case Twitter
    
    func login() {
        switch self {
        case let .Email(user) where user.isValid():
            // login!
            break
        default:
            break
        }
    }
}

我们在枚举中定义方法以后,我们的登录方案就显得很完整了,而且非常的简洁。

var lp = LoginProvider.Email(user)
lp.login()

关于这部分内容并没有结束,因为反对意见还没有出场,如果感兴趣可以关注我的下一篇内容:这样做并不怎么好。

** 原作者非常看重枚举能够把不同的内容整合在一起并体现统一的类型。如果没有枚举的帮助,在统一各种不同的登录SDK上面,我们确实需要在协议和实现上面花不少功夫,而且枚举提供非常棒的特性,能够进一步抽象业务逻辑,总之swift的枚举是非常值得点赞的**

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容