平时用 Code 写 UI,经常要修改不同的属性,自己对代码的格式又有点强迫症,有时候要不断手动对齐等号和空格。 现在写个将 UIKit 里面常用的赋值的操作改为点语法的库,充分利用编译器提示,减少等号键和空格键的输入。
地址在这里: https://github.com/E13Lau/DotKit
示例 使用前
let label = UILabel() label.textAlignment = .center label.text = "Hola!" label.numberOfLines = 0 label.setContentHuggingPriority(.defaultHigh, for: .vertical) label.layer.cornerRadius = 5 label.layer.borderWidth = 1 label.layer.borderColor = UIColor.red.cgColor
使用后
let label = UILabel() .dd .textAlignment(.center) .text("Hola!") .numberOfLines(0) .asSubviewAdd(to: view) .setContentHuggingPriority(.defaultHigh, for: .vertical) .configLayer { $0.dd .cornerRadius(5) .borderWidth(1) .borderColor(UIColor.red.cgColor) } .base
与这个库配套的还有 https://github.com/E13Lau/DotKit-SnapKit
它会把 SnapKit 的方法纳入 dd 这个命名空间下并且同样会在方法后返回自身
所以可以像这样使用 SnapKit
UIView() .dd .asSubviewAdd(to: view) .makeConstraints { $0.left.top.right.equalToSuperview() $0.height.equalTo(100) } .backgroundColor(.red)
![]() | 1 littlemcdull 2021-05-31 10:55:48 +08:00 这就是 builder 模式吧,swiftUI 就这样 |
![]() | 2 wipbssldo OP @littlemcdull 应该是。我之前用 SwiftUI 写个 App,很喜欢 SwiftUI,写起来只需要点+回车。可惜公司的项目还不能用 SwiftUI,只能写写这样的库安慰一下自己。 |