余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

成为优秀Swift开发者的10条建议(swift开发框架)

xiyangw 2022-12-03 12:37 31 浏览 0 评论

1. Extension 扩展

举例:平方

成为优秀Swift开发者的10条建议(swift开发框架)

// Okay Version
func square(x: Int) -> Int { return x * x }
var squaredOFFive = square(x: 5)
square(x:squaredOFFive) // 625

创建无效变量,将5平方后再平方 —— 毕竟我们不喜欢打字。

// Better Version
extension Int { 
 var squared: Int { return self * self }
}
5.squared // 25
5.squared.squared // 625

2. Generics 泛型

举例:打印数组中的所有元素

// Bad Code
var stringArray = ["Bob", "Bobby", "SangJoon"]
var intArray = [1, 3, 4, 5, 6]
var doubleArray = [1.0, 2.0, 3.0]
func printStringArray(a: [String]) { for s in a { print(s) } }
func printIntArray(a: [Int]) { for i in a { print(i) } }
func printDoubleArray(a: [Double]) {for d in a { print(d) } }

对于很多无效的函数,我们只需创建一个就可。

// Awesome Code
func printElementFromArray<T>(a: [T]) {
 for element in a { print(element) } }

3. For 循环 vs While 循环

举例:打印5次 “Count”

// Okay Code
var i = 0
while 5 > i {
print("Count")
i += 1 }

创建变量“i”以确保你电脑打印有限的数字不会崩溃。

要记住:变量越多 → 记忆越多 → 越麻烦 → bug越多 → 问题越多。蝴蝶效应要谨记

// Better Code
for _ in 1...5 { print("Count") }

4. 有选择的展开

举例:Gaurd let vs if let

我们来写一个欢迎新用户的程序。

var myUsername: Double?
var myPassword: Double?
// Hideous Code
func userLogIn() {
 if let username = myUsername {
 if let password = myPassword {
 print("Welcome, \(username)"!)
 }
 }
}

你看到世界末日的金字塔了吗?嵌套的代码太让人讨厌了。坚决不要!把糟糕的代码去掉,改成更好的。

// Pretty Code
func userLogIn() {
 guard let username = myUsername, let password = myPassword 
 else { return } 
 print("Welcome, \(username)!") }

上下两者的差别是显而易见的。如果用户名或密码有一个零值,优雅的代码会调用“return”提前退出。否则,会出现欢迎的信息。

5. 计算属性 vs 函数

举例:求圆的直径

func getDiameter(radius: Double) -> Double { return radius * 2}
func getRadius(diameter: Double) -> Double { return diameter / 2}
getDiameter(radius: 10) // return 20
getRadius(diameter: 200) // return 100
getRadius(diameter: 600) // return 300

上面创建了两个互斥函数。太糟糕了!我们将半径和直径之间的点连接起来。

// Good Code
var radius: Double = 10
var diameter: Double {
 get { return radius * 2}
 set { radius = newValue / 2} } 
radius // 10
diameter // 20
diameter = 1000 
radius // 500

现在,半径和直径变量是互相独立的。连接越多 → 额外输入越少 → 错误更少 → bug越少 → 问题越少。

6. 类型安全枚举

举例:售票

// Simply Bad
switch "Adult" {
 case "Adult": print("Pay $7")
 case "Child": print("Pay $3")
 case "Senior": print("Pay $4")
 default: print("You alive, bruh?") }

“Adult”, “Child”, “Senior” → 这是在硬编码,逐一地将每个情况的字符串打出来,万万不可。上面已经解释过,写太多会出什么问题。我们可一点都不喜欢打字。

// Beautiful Code
enum People { case adult, child, senior }
switch People.adult {
 case .adult: print("Pay $7")
 case .child: print("Pay $3")
 case .senior: print("Pay $4")
 default: print("You alive, bruh?") }

“.adult”, “.child”, “.senior” 重点标注肯定是没错的。如果switch语句超过指定枚举的范围遇到一些未知情况,左边发生红色错误(),Xcode会报警。—— 找不到合适的表情啦。

7. 无效合并

举例:用户选择Twitter主题色

// Long Code
var userChosenColor: String? 
var defaultColor = "Red"
var colorToUse = "" 
if let Color = userChosenColor { colorToUse = Color } else
 { colorToUse = defaultColor }

这代码太长了,我们缩短一下。

// Concise AF
var colorToUse = userChosenColor ?? defaultColor

上边代码的意思是,如果userChosernColor返回零值(无效),选择defaultColor (red),否则,选择userChosenColor.

8. 有条件的合并

举例:鸡冠头(SpikyHair)显高

// Simply Verbose
var currentHeight = 185
var hasSpikyHair = true
var finalHeight = 0
if hasSpikyHair { finalHeight = currentHeight + 5} 
 else { finalHeight = currentHeight }

上面的代码太长了,我们来给它瘦瘦身。

// Lovely Code
finalHeight = currentHeight + (hasSpikyHair ? 5: 0)

上面的代码意思是,如果hasSpikeHaire是真实的,最后的高度增加5;如果是假的,最后的高度加0(不增加)。

9. 函数式编程

举例:获取偶数

// Imperative (a.k.a boring)
var newEvens = [Int]()
for i in 1...10 {
 if i % 2 == 0 { newEvens.append(i) } }
print(newEvens) // [2, 4, 6, 8, 10]

不需要了解全过程。review上面的for循环太浪费时间了,其实可以更清晰一些。

// Declarative
var evens = Array(1...10).filter { $0 % 2 == 0 } 
print(evens) // [2, 4, 6, 8, 10]

函数式编程是现象级的,会让你变得更聪明。

10. Closure vs Func

// Normal Function 
func sum(x: Int, y: Int) -> Int { return x + y }
var result = sum(x: 5, y: 6) // 11

不需要记住函数和变量的名字。

// Closure
var sumUsingClosure: (Int, Int) -> (Int) = { $0 + $1 }
sumUsingClosure(5, 6) // 11

相关推荐

Vue的框架(了解)

前端MVC设计模式MVC设计模式,其实就是将前端实现某个业务的所有代码划分为三部分Model:模型,指数据模型,这个数据一般来自于服务器View:视图,指页面标签内容Controller:控制...

Vue.js实战 第五章练习一

练习要求:在原有表格基础上,新增一项是否选中该商品的功能,总价变为只计算选中商品的总价,同时提供一个全选的按钮。实现思路:按照vue数据和dom元素双向绑定的特性,定义allCheckStatus变量...

Vue基础到进阶教程之class和style绑定

关于class和style我们并不陌生,这个在学习css的时候就是家常便饭了,操作元素的class列表和内联样式是数据绑定的一个常见需求。因为它们都是属性,所以我们可以用v-bind处理它们,...

深入Vue 必学高阶组件 HOC「进阶篇」

作者:ssh转发连接:https://mp.weixin.qq.com/s/seKoLSIMtTd1sU4uDrgZCA前言高阶组件这个概念在React中一度非常流行,但是在Vue的社区里讨论...

周末大礼包,23道高质量中级前端面试题。金九银十,建议收藏

这套面试题考察的内容比较常见,涉及到JavaScript、ES6、CSS、Vue、简单算法,浏览器相关知识等。题目列表1.JavaScript的数据类型有哪些2.什么是同源策略3.跨域的方法...

vue3.0-摒弃Object.defineProperty,基于 Proxy 的观察者机制

写在前面:11月16日早上,Vue.js的作者尤大大在VueToronto的主题演讲中预演了Vue.js3.0的一些新特性,其中一个很重要的改变就是Vue3将使用ES6的Proxy作...

程序员都必掌握的前端教程之VUE基础教程(七)

阅读本文约需要10分钟,您可以先关注我们,避免下次无法找到。本篇文章成哥继续带大家来学习前端VUE教程,今天主要讲解VUE的表单处理等知识点。下面我们就一起来学习该块内容吧!01简介在日常开发中,我...

web前端开之网站搭建框架之vue详解

网站搭建框架之vueVue是web前端快速搭建网站的框架之一。它与jQuery有所不同,是以数据驱动web界面(以操作数据改变页面,而jQuery是以操作节点来改变页面),同时,vue还实现了数据的双...

vue3.0尝鲜-基于 Proxy 的观察者机制探索

Vue.js的作者尤大大在VueToronto的主题演讲中预演了Vue.js3.0的一些新特性,其中一个很重要的改变就是Vue3将使用ES6的Proxy作为其观察者机制,取代之前使用...

TypeScript 设计模式之观察者模式

一、模式介绍1.背景介绍在软件系统中经常碰到这类需求:当一个对象的状态发生改变,某些与它相关的对象也要随之做出相应的变化。这是建立一种「对象与对象之间的依赖关系」,一个对象发生改变时将「自动通知其他...

vue面试3

1.单页面应用与多页面应用的去别2.简述一下Sass、Less,且说明区别?他们是动态的样式语言,是CSS预处理器,CSS上的一种抽象层。他们是一种特殊的语法/语言而编译成CSS。变量符不一样,les...

VUE v-bind 数据绑定

动态的绑定一个或多个attribute,也可以是组件的prop。缩写::或者.(当使用.prop修饰符)期望:any(带参数)|Object(不带参数)参数:attrOrP...

vue初学习之自定义选择框实现

v-model简单介绍在使用vue的过程中会经常用到input和textarea这类表单元素,vue对于这些元素的数据绑定和我们以前经常用的jQuery有些区别。vue使用v-model实现这些标签...

Vue实现拖拽穿梭框功能四种方式

一、使用原生js实现拖拽打开视频讲解更加详细Vue实现拖拽穿梭框功能的四种方式_哔哩哔哩_bilibili<html><head><meta...

Vue3.x setup 语法糖实现props双向绑定

1.背景为了封装一下Element-Plus的分页插件,需要实现父子组件之间的传值。2.父组件<scriptsetuplang="ts">letqueryPa...

取消回复欢迎 发表评论: