首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使按钮跨越VStack

使按钮跨越VStack
EN

Stack Overflow用户
提问于 2019-06-06 04:44:47
回答 8查看 17.7K关注 0票数 20

我目前有以下SwiftUI视图:

代码语言:javascript
复制
HStack {
  ...
  VStack {
    TextField { ... }
    SecureField { ... }
    Button { ... }
  }
  ...
}

我向.background(Color.green)添加了一个Button,正如您所看到的,视图非常适合文本。

我想知道是否有一种方法来调整按钮的宽度,使其在整个VStack中填充--类似于UIStackView.fill模式。

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2019-06-06 07:17:32

最好的方法是通过.frame(maxWidth: .infinity) https://developer.apple.com/documentation/swiftui/view-layout

如果希望按钮不居中,则需要指定alignment

例如:.frame(maxWidth: .infinity, alignment: .leading)

代码语言:javascript
复制
Button(action: handleSignInAction) {
    Text("Sign In")
}
.frame(maxWidth: .infinity)
.background(Color.green)

2019年的旧答案:

您可以使用带有HStackTextSpacerButton来获取一个填充其父级宽度的Button

代码语言:javascript
复制
Button(action: handleSignInAction) {
    HStack {
        Spacer()
        Text("Sign In")
        Spacer()
    }
}.background(Color.green)
票数 35
EN

Stack Overflow用户

发布于 2019-08-02 21:00:34

@d.felber的答案几乎已经完成,但是您需要在每一侧都有一个Spacer()来进行中间操作:

代码语言:javascript
复制
Button(action: {
    // TODO: ...
}) {
    HStack {
        Spacer()
        Text("Sign In")
        Spacer()
    }
}
票数 13
EN

Stack Overflow用户

发布于 2020-05-02 04:40:21

代码语言:javascript
复制
.frame(maxWidth: .infinity)

为我做了个小把戏。

票数 10
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56471004

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档