當前位置: 首頁>>編程示例 >>用法及示例精選 >>正文


Swift Optional onChange(of:perform:)用法及代碼示例

實例方法

onChange(of:perform:)

為這個視圖添加一個修飾符,當一個特定的值改變時觸發一個動作。

聲明

func onChange<V>(
    of value: V,
    perform action: @escaping (V) -> Void
) -> some View where V : Equatable

返回值

當指定值更改時觸發操作的視圖。

參數

value

在確定是否運行閉包時要檢查的值。

action

值更改時運行的閉包。

newValue

未通過比較檢查的新值。

詳述

您可以使用 onChange 作為值更改的結果來觸發副作用,例如 Environment 鍵或 Binding

onChange 在主線程上調用。避免在主線程上執行long-running 任務。如果您需要執行 long-running 任務以響應 value 更改,則應分派到後台隊列。

新值被傳遞到閉包中。閉包可以捕獲先前的值,以將其與新值進行比較。例如,在以下代碼示例中,PlayerView 將舊值和新值都傳遞給模型。


struct PlayerView: View {
    var episode: Episode
    @State private var playState: PlayState = .paused


    var body: some View {
        VStack {
            Text(episode.title)
            Text(episode.showTitle)
            PlayButton(playState: $playState)
        }
        .onChange(of: playState) { [playState] newState in
            model.playStateDidChange(from: playState, to: newState)
        }
    }
}

可用版本

iOS 14.0+, iPadOS 14.0+, macOS 11.0+, Mac Catalyst 14.0+, tvOS 14.0+, watchOS 7.0+

相關用法


注:本文由純淨天空篩選整理自apple.com大神的英文原創作品 Optional onChange(of:perform:)。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。