考虑以下将填充应用于特定View
的ViewModifier
enum Padding {
case small
case medium
case large
}
private struct PaddingModifier: ViewModifier {
var edgeSet: Edge.Set = .all
var size: Padding
func body(content: Content) -> some View {
return content.padding(edgeSet, getSize())
}
func getSize() -> CGFloat {
switch size {
case .small:
return 2
case .medium:
return 8
case .large:
return 16
}
}
}
为了使 ViewModifier
更具可读性,通常我会向 View
添加扩展函数
extension View {
func padding(_ size: Padding, _ set: Edge.Set = .all) -> some View {
return modifier(PaddingModifier(edgeSet: set, size: size))
}
}
但是,假设我想将此修饰符应用于任意 Edge.Set
值列表。如何编写一个带有签名 (Padding, [Edge.Set]) -> some View
的函数,该函数为每个 Edge.Set
应用 PaddingModifier
>?
我的第一个想法是像下面这样,但是Self
不能符合some View
extension View {
func padding(_ size: Padding, _ set: Edge.Set = .all) -> some View {
return modifier(PaddingModifier(edgeSet: set, size: size))
}
func padding(_ size: Padding, _ set: [Edge.Set]) -> some View {
set.reduce(self) { $0.padding(size, $1) }
}
}
最佳答案
Edge.Set
是一个 OptionSet
,因此使用第一个修饰符就可以进行编码(类似于内置 .padding([.leading , .trailing], 20)
)
Text("Demo")
.padding(.small, [.leading, .trailing])
看起来 padding(_ size: Padding, _ set: [Edge.Set])
想太多了。
关于swift - 是否可以编写一个函数来组成任意数量的 SwiftUI `ViewModifier' s?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61789064/