๐Ÿ…ฟ๏ธViewModifier

โ•ฑ๐Ÿšง under construction

SwiftUI โŸฉ views โŸฉ modifier โŸฉ ViewModifier (protocol)

protocol ViewModifier {
    typealias Content            // input type of body()
    associatedtype Body: View    // output type of body()
    // โญ๏ธ only requirement
   func body(content: Self.Content) -> Self.Body
}

๐Ÿ’พ ๆจกๆฟ

import SwiftUI

// (internal) view modifier
struct MyViewModifier: ViewModifier {
    
    // โญ๏ธ new states
    @State private var blur = true              
    
    // body
    func body(content: Content) -> some View {
        // โญ๏ธ handle input `content`
        content
            .blur(radius: blur ? 20 : 0)
            .clipped()
            .onTapGesture { 
                withAnimation {
                    self.blur.toggle()
                }
            }
    }
}

// โญ๏ธ public helper
extension View {
    public func myModifier() -> some View { 
        modifier(MyViewModifier()) 
    }
}

Last updated

Was this helpful?