Swift代码规范

当你试图解决一个别人代码中的问题时,难得不是怎么解决这个问题,而是先得找到、读懂这段代码。

推荐文档:https://github.com/raywenderlich/swift-style-guide#naming

我在找同事写的代码

一:工程目录结构规范

1、除了注释外,所有的资源命名都用英文,不要用魔术数字、汉字。

2、推荐一个规范的工程目录结构

工程目录结构

Macro['mækro]:存放公用头文件比如:URL,宏定义,通知,枚举等等。

Storage['stɔrɪdʒ]:存放封装HTTP请求和数据库操作文件。

Resources[risɔrsiz]:存放html、音频、视频、图片等资源文件。

Extra['ɛkstrə]:存放第三方SDK,如:百度地图SDK,支付宝SDK等等

Vendors['vɛndɚz]:存放工程中封装的一些公用方法 或 SDK。

Control[kən'trol]:存放网络请求(HTTP)Manager、数据库(DB)操作等类文件。

View[vju]:存放所有自定义界面View。

Model['mɑdl]:负责解析HTTP下来的数据。

Controller[kən'trolɚ]:存放所有控制器类。

3、所有的ViewController都应继承自一个BaseViewController(大家懂的)。

4、文件命名、类名应以相应模块英文单词为准,不要用魔术数字命名,比如:

Controller目录

5、StoryBoard使用:界面跳转用代码实现,不建议用拖关系线条,方便后期维护。

6、界面适配,建议用 AutoLayout 放弃 Autoresizing,随着大屏iPhone推出,苹果主推 AutoLayout 技术。

8、所有的类名和逻辑方法,要加注释。

9、所有的公用方法,都抽成一个公用类里。

10、不要用虚拟目录,如果需要在工程中添加新的文件夹,使用 Add File To 方法添加。

11、推荐一个 ViewController 注释模板

// MARK: - LifeCycle

override func viewDidLoad() {

    super.viewDidLoad()

}

// MARK: - Intial Method

// MARK: - HTTP Method

// MARK: - Action Method

// MARK: - Private Method

// MARK: - UITableViewDataSource

// MARK: - UITableViewDelegate

// MARK: - CustomDelegate

// MARK: - Target Method

// MARK: - Setter Getter Method


二:代码规范

1、尽可能使你的工程中不要出现代码警告,因为警告过多时也会造成一些未知错误。对于第三方库中的警告,你也应该积极清除掉。

2、Delegate方法名称

建议:使用参数标签,并且在第一个参数使用下划线( _ )来代替一个明确的参数标签

func namePickerView(_ namePickerView: NamePickerView, didSelectName name: String)

func namePickerViewShouldReload(_ namePickerView: NamePickerView) -> Bool

不建议:

func didSelectName(namePicker: NamePickerViewController, name: String)

func namePickerShouldReload() -> Bool

3、属性赋值

建议:

let selector = #selector(viewDidLoad)

view.backgroundColor = .red

let toView = context.view(forKey: .to)

let view = UIView(frame: .zero)

不建议:

let selector = #selector(ViewController.viewDidLoad)

view.backgroundColor = UIColor.red

let toView = context.view(forKey: UITransitionContextViewKey.to)

let view = UIView(frame: CGRect.zero)

4、类、函数注释

给类加名称注释有很大的帮助,我们往往知道一个页面的 title,却不知道这个页面在工程中对应的类(尤其是当你要修改小伙伴写的代码)。如果你的小伙伴,给他的类加了名称注释,根据名称在工程中全局搜索,你将能很快搜到这个类。

// 首页

class HomeViewController: UIViewController {

// class stuff here

}

5、if语句

建议:

if user.isHappy {

// Do something

} else {

// Do something else

}

不建议:

if user.isHappy

{

// Do something

}

else {

/ Do something else

}

6、变量声明

建议:

var data = ["A": 1.2, "B": 3.2]

不建议:

var data :[String:CGFloat] = ["A" : 1.2, "B":3.2]

var data : [String:CGFloat] = ["A" : 1.2, "B":3.2]

7、方法声明

func reticulateSplines(spline: [Double]) -> Bool {

// reticulate code goes here

}

如果函数参数较多,使用换行表示

func reticulateSplines(spline: [Double],

                 adjustmentFactor: Double,

                 translateConstant: Int, comment: String) -> Bool {

                // reticulate code goes here

}

8、声明变量

建议:Swift有类型推断机制,可以根据初始化赋值的类型推断出变量、常量的值

let width = 120.0                                    // Double

let widthString = (width as NSNumber).stringValue    // String

不建议:

let width: NSNumber = 120.0                          // NSNumber

let widthString: NSString = width.stringValue        // NSString

9、调用方法

建议:

if let textContainer = self.textContainer {

// do many things with textContainer

}

不建议:

self.textContainer?.textLabel?.setNeedsDisplay()

10、嵌套if语句

建议:

var subview: UIView?

var volume: Double?

if let subview = subview, let volume = volume {

// do something with unwrapped subview and volume

}

不建议:

var optionalSubview: UIView?

var volume: Double?

if let unwrappedSubview = optionalSubview {

    if let realVolume = volume {

        // do something with unwrappedSubview and realVolume

    }

}

11、定义空数组

建议:

var names: [String] = []

var lookup: [String: Int] = [:]

不建议:

var names = [String]()

var lookup = [String: Int]()

13、数组

建议:

var deviceModels: [String]

var employees: [Int: String]

var faxNumber: Int?

不建议:

var deviceModels: Array<String>

var employees: Dictionary<Int, String>

var faxNumber: Optional<Int>

14、闭包

建议:

resource.request().onComplete { [weak self]

response in

guard let this = self else {

    return

}

let model = this.updateModel(response)

this.updateUI(model)

}

不建议:

resource.request().onComplete { [unowned self] response in

let model = self.updateModel(response)

self.updateUI(model)

}

resource.request().onComplete { [weak self] response in

let model = self?.updateModel(response)

self?.updateUI(model)

}

15、循环语句

建议:

for _ in 0..<3 {

print("Hello three times")

}

for (index, value) in dataArray.enumerated() {

print("\(value) is at position #\(index)")

}

for index in stride(from: 0, to: dataArray.count, by: 2) {

print(index)

}

for index in dataArray.reversed() {

print(index)

}

不建议:

var i = 0

while i < 3 {

print("Hello three times")

i += 1

}

var i = 0

while i < attendeeList.count {

let person = attendeeList[i]

print("\(person) is at position #\(i)")

i += 1

}

16、分号(在Swift中不用给每个语句后面加分号,换行代表这条语句结束,如果两条语句写在同一行,则必须在第一条语句后加分号,但不建议这种写法)

建议:

let swift = "not a scripting language"

不建议:

let swift = "not a scripting language";

17、if语句

建议:

if name == "Hello" {

print("World")

}

不建议:

if (name=="Hello")  {

print("World")

}

18、在写代码时,应该遵循面向对象六大原则

1、单一职责原则(SRP):一个类应该只有一个发生变化的原因。

2、开放封闭原则(OCP):对扩展是开放的,而对修改是封闭的。

3、Liskov替换原则(LSP):主要是通过抽象和多态来实现,而抽象和多态的实现又来自继承。

4、依赖倒置原则(DIP):针对接口编程,而不是针对实现编程。

5、接口隔离原则(ISP):使用多个隔离的接口,比使用单个接口要好。

6、迪米特原则(LOD):一个实体应当尽量少的与其他实体之间发生相互作用,使得系统功能模块相对独立。

19、常用CGRect方法

let greenView = UIView(frame: CGRect(x: 100, y: 100, width: 100, height: 100))

// 获取view的最小X值,也就是这个view的X值

let minX: CGFloat = greenView.frame.minX

// 获取view的最大的X值,也就是这个view的X值+view的宽

let maxX: CGFloat = greenView.frame.maxX

// 获取view的最小Y值,也就是这个view的Y值

let minY: CGFloat = greenView.frame.minY

// 获取view的最大Y值,也就是这个view的Y值+view的高度

let maxY: CGFloat = greenView.frame.maxY

// 获取view的中点X

let midX: CGFloat = greenView.frame.midX

// 获取view的中点Y

let midY: CGFloat = greenView.frame.midY

20、协议:如果一个类中的协议太多时,可以用 extension 去实现协议

建议:

class MyViewController: UIViewController {

// class stuff here

}

// MARK: - UITableViewDataSource

extension MyViewController: UITableViewDataSource {

// table view data source methods

}

// MARK: - UIScrollViewDelegate

extension MyViewController: UIScrollViewDelegate {

// scroll view delegate methods

}

不建议:

class MyViewController: UIViewController, UITableViewDataSource, UIScrollViewDelegate {

// all methods

}

21、工程中我们常用的是MVC目录(Controller、Model、View),为了好区分模块,我们又会在每个目录下创建功能目录文件夹,比如在Controller下创建Home(主页)、Order(订单)、Me(个人中心),依次类推,当模块较多时,这样也会导致工程看起来很乱。此时,我们可以这样划分:在每个功能目录下创建MVC目录(Controller、Model、View),这样把MVC细分到每个功能,这样就更简单了。

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

推荐阅读更多精彩内容