You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
2.3 KiB
2.3 KiB
Managing State
With SwiftUI you can create state in views and pass that state to child views, much as you would in React. You can also pass functions as props which allow child views to control state in parent components.
The example below creates a simple counter. The ContentView
manages the count
state, while the child view renders that count and asks the parent to increment.
React
import React from "react";
export function ContentView() {
const [count, setCount] = useState(0);
function increment() {
setCount(count + 1);
}
return (
<div>
<div>Press the button below</div>
<ChildView count={count} increment={increment} />
</div>
);
}
export function ChildView({ count, increment }) {
return (
<div>
<div>{coun t}</div>
<button onClick={increment}>Increment</button>
</div>
);
}
SwiftUI
import SwiftUI
struct ContentView : View {
@State var count = 0
var body: some View {
VStack(spacing: 1.0) {
Text("Press the button below")
ChildView(
counter: count,
increment: increment
)
}
}
func increment() {
count += 1
}
}
struct ChildView : View {
var counter: Int
var increment: () -> Void
var body: some View {
VStack {
Text("\(counter)")
Button(action: increment) {
Text("Increment")
}
}
}
}
With SwiftUI you can use @Binding
to enable child views to alter state provided by parent views. Notice that we prepend the $
to our count value to pass its binding value. Our child can then alter the count
state itself without supplying a callback to the parent.
import SwiftUI
struct ContentView : View {
@State var count = 0
var body: some View {
VStack(spacing: 1.0) {
Text("Press the button below")
ChildView(
counter: $count
)
}
}
}
struct ChildView : View {
@Binding var counter: Int
func increment () {
counter += 1
}
var body: some View {
VStack {
Text("\(counter)")
Button(action: increment) {
Text("Increment")
}
}
}
}