在 Z 和 HStack 中添加 2 个背景?

Adding 2 backgrounds within a Z and HStack?

提问人:Summer 提问时间:5/8/2021 更新时间:5/8/2021 访问量:270

问:

color.red 是我的小部件的主要背景,但我想在文本“Line1”和图像“2”后面的顶部添加一个黑色背景。所以基本上是一个黑条,延伸到文本和图像下方的顶部。

var body: some View {
    ZStack {
        Color.red
        
        VStack(alignment: .leading, spacing: 0) {
            HStack {
                Text("Line1")
                    .foregroundColor(.orange)
                    .bold()
                    .font(.system(size: 17.5))
                    .padding(.top)
                Spacer()
                
                Image("2")
                    .resizable()
                    .frame(width: 25, height: 25)
                    .padding(.top)
                
            }
            .padding(.horizontal)
            .border(Color.green)
            
            VStack(alignment: .leading) {
                Image("2")
                    .resizable()
                    .frame(width: 67, height: 30)
                
                Text("State")
                    .foregroundColor(Color.green)
                    .font(.system(size: 15))
                
                Text("1")
                    .foregroundColor(Color.blue)
                    .font(.system(size: 10))
                    .opacity(0.5)
                
                Spacer()
                Spacer()
            }
            .padding(.horizontal)
            .border(Color.blue)
        }
    }
}
Swift SwiftUI 小部件

评论


答:

4赞 jnpdx 5/8/2021 #1

您可以在第一个中添加修饰符:.backgroundHStack

HStack {
    //content here             
}
.padding(.horizontal)
.border(Color.green)
.background(Color.black)

请记住,修饰符的顺序很重要,所以如果你把 放在填充之前,填充就不会有那个背景颜色——这就是我最后使用它的原因。background