平时用 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,只能写写这样的库安慰一下自己。
|