SwiftUI Tips:在 ViewBuilder 中方便的打印调试信息

我们在调试 SwiftUI View 的时候有时需要在打印一些内容。最常见的打印方式是使用print

swift 复制代码
struct ContentView: View {
    var body: some View {
        VStack {
            Image(systemName: "globe")
                .foregroundStyle(.tint)
            let _ = print("my log")
            Text("Hello, world!")
        }
        .padding()
    }
}

但是如果想要打印某个 View 节点的信息(类型、属性)就有点不方便了。

假设我有一个自定义的控件,MyText,有一个公开的属性 title

swift 复制代码
struct MyText: View {
    let title: String
    
    var body: some View {
        Text(title)
            .foregroundColor(.red)
    }
}

要如何调试打印这个 MyText 的title 呢?这个时候直接使用 print 就不好用了。硬来的话只能多复制一个 MyText 了:

swift 复制代码
struct PrintView: View {
    var body: some View {
        VStack {
            MyText(title: "我的内容")
            let _ = print("mylog:\(MyText(title: "我的内容").title)")
        }
        .padding()
    }
}

可以通过自定义一个泛型打印函数来解决这个问题:

swift 复制代码
func printThrough<T>(
    _ t: T, 
    _ message: String? = nil, 
    map: ((T) -> String)? = nil
) -> T {
    let description = if let map {
        map(t)
    } else {
        String(describing: t)
    }

    let message = if let message {
        "\(message): '\(description)'"
    } else {
        description
    }

    print(message)

    return t
}

printThrough 第一个参数接收任意内容(view)。第二个参数可空接收要打印的字符串前缀,如果没有传入默认打印第一个参数的类型信息。第三个参数是个闭包,在闭包中可以获得第一个参数的实例,用于打印自定义的实例信息。

有了这个函数以后我们前面的需求就可以优雅地实现了:

swift 复制代码
struct ContentView: View {
    var body: some View {
        VStack {
            printThrough(
                Text("Hello, world!")
            )
            printThrough(
                MyText(title: "我的内容"),
                "MyLog",
                map: { "内容是:\($0.title)"})
        }
        .padding()
    }
}

控制台就会输出这样的结果:


相关推荐
黄鹤的小姨子1 天前
SwiftUI 劝退实录:AI 都无能为力,你敢用吗?
swiftui
麦兜*2 天前
【swift】SwiftUI动画卡顿全解:GeometryReader滥用检测与Canvas绘制替代方案
服务器·ios·swiftui·android studio·objective-c·ai编程·swift
东坡肘子6 天前
苹果首次在中国永久关闭了一家 Apple Store | 肘子的 Swift 周报 #097
swiftui·swift·apple
大熊猫侯佩10 天前
WWDC 25 玻璃态星际联盟:SwiftUI 视图协同“防御协议”
swiftui·swift·wwdc
东坡肘子13 天前
Xcode 26 beta 4,要崩我们一起崩 | 肘子的 Swift 周报 #096
swiftui·swift·apple
吴Wu涛涛涛涛涛Tao14 天前
SwiftUI 打造 TikTok 风格的滑动短视频播放器
ios·swiftui
大熊猫侯佩16 天前
代码精讲:WWDC 25 @Animatable 宏 —— SwiftUI 动画的新突破
swiftui·swift·wwdc
大熊猫侯佩17 天前
SwiftUI Charts 入门:从零到一,笑谈“柱”状人生(二)
swiftui·swift·apple
大熊猫侯佩17 天前
SwiftUI Charts 入门:从零到一,笑谈“柱”状人生(三)
swiftui·swift·apple
大熊猫侯佩17 天前
SwiftUI Charts 入门:从零到一,笑谈“柱”状人生(一)
swiftui·swift·apple