SwiftUI-在视图中包装Button,以创建自定义按钮

问题描述 投票:0回答:2

我正在尝试通过将其包装在视图中来创建自己的Button版本,从而开放了添加更多功能/隐藏样式修改器的功能。我知道这并没有带来好处,而且ButtonStyles很强大。但是出于超级简洁代码的利益,我对如何实现它很感兴趣。

以最简单的形式,我想写类似(基于Button自己的签名):

struct MyCustomButton: View {
    let action : () -> Void
    let contents : () -> PrimitiveButtonStyleConfiguration.Label

    var body : some View {
        Button(action: self.action) {
            self.contents()
        }
    }
}

但是当我尝试使用它时...

struct MyView : View {
    var body : some View {
        MyCustomButton(action: { doSomething() }) {
            Text("My custom button")
        }
    }
}

...我收到以下编译错误:无法将'文本'类型的值转换为关闭结果类型'PrimitiveButtonStyleConfiguration.Label'

button swiftui
2个回答
0
投票

[您不需要更改Button,根据SwiftUI的设计意图,只需提供自定义ButtonStyle,如下面的示例。

struct ScaleButtonStyle: ButtonStyle {
    let bgColor: Color
    func makeBody(configuration: Self.Configuration) -> some View {
        configuration.label
            .background(bgColor)
            .scaleEffect(configuration.isPressed ? 5 : 1)
    }
}

struct DemoScaleButtonStyle: View {
    var body: some View {
        Button(action: { }) {
            Text("Button")
                .foregroundColor(.white)
        }.buttonStyle(ScaleButtonStyle(bgColor: Color.red))
    }
}


0
投票

已经弄清楚了:

struct NewButton<Content: View> : View {
    let content : ()-> Content
    let action: () -> Void

    init(@ViewBuilder content: @escaping () -> Content, action: @escaping () -> Void) {
        self.content = content
        self.action = action
    }

    var body: some View {
        Button(action: self.action) {
            content()
        }
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.