swift ui 数据绑定

前言:

最近在学习iOS swift ui 里面的数据绑定 ,就想着记录下 然后分享给大家。

效果图:

看上图我们需求很明确 我们需要将输入框里面内容来替换掉我们的标题

具体实现

scss 复制代码
   VStack{
            Text(self.title)
                .font(.title)
            TextField("请输入内容",text: self.$textInput)
                .font(.title)
                .frame(width: UIScreen.main.bounds.width-20, height: 50, alignment: .center)
                .padding(10)
                .textFieldStyle(RoundedBorderTextFieldStyle())
        }

我们写了一个 VStack 垂直的的线性布局 我们里面写了一个text 来显示标题和 textfiled 输入框来显示我们的基础ui

点击button 将我们输入框拿到内容赋值给我们的标题

scss 复制代码
 Button(action: {
                self.title=self.textInput
            }, label: {
                Text("确定")
                    .font(.largeTitle)
                    .padding()
                    .background(Color.blue)
                    .foregroundColor(.white)
                    .cornerRadius(15)
            })

完整代码

less 复制代码
//
//  ContentView.swift
//  databinding
//
//  Created by xuqing on 2021/11/22.
//
import SwiftUI
struct ContentView: View {
    @State private var textInput:String=""
    @State private var title:String="我是徐老板"
    var body: some View {
        VStack{
            Text(self.title)
                .font(.title)
            TextField("请输入内容",text: self.$textInput)
                .font(.title)
                .frame(width: UIScreen.main.bounds.width-20, height: 50, alignment: .center)
                .padding(10)
                .textFieldStyle(RoundedBorderTextFieldStyle())
            Button(action: {
                self.title=self.textInput
            }, label: {
                Text("确定")
                    .font(.largeTitle)
                    .padding()
                    .background(Color.blue)
                    .foregroundColor(.white)
                    .cornerRadius(15)
            })
        }
    }
}

struct ContentView_Previews: PreviewProvider {
    static var previews: some View {
        ContentView()
    }
}

最后总结:

swift ui 里面的数据绑定 思想和vue总体来说很像 比较容易做到数据的双向绑定 以前我们用uikt和oc 开发要写很多代码来实现的 swift ui里面简化了很多。同学们有兴趣可以私下多深入去了解下。

相关推荐
东坡肘子2 天前
从开放平台到受控生态:谷歌宣布 Android 开发者验证政策 | 肘子的 Swift 周报 #0101
android·swiftui·swift
HarderCoder3 天前
深入理解 SwiftUI 的 Structural Identity:为什么“换个条件分支”就会丢状态?
swiftui·swift
YungFan3 天前
Swift 6.2 新特性
swiftui·swift
大熊猫侯佩7 天前
当液态玻璃计划遭遇反叛者:一场 iOS 26 界面的暗战
swiftui·xcode·apple
雪糕吖7 天前
SwiftUI 自定义 Shape:实现顶部圆角矩形 RoundedTopRectangle
ios·swiftui
东坡肘子9 天前
写给这段旅程,也写给未来的自己 | 肘子的 Swift 周报 #0100
swiftui·swift·apple
大熊猫侯佩15 天前
SwiftUI 三阵诀:杨过绝情谷悟 “视图布阵” 之道
swiftui·swift·apple
东坡肘子16 天前
未来将至:人形机器人运动会 | 肘子的 Swift 周报 #099
swiftui·swift·apple
吴Wu涛涛涛涛涛Tao19 天前
基于TCA构建Instagram克隆:SwiftUI状态管理的艺术
ios·swiftui
麦兜*22 天前
Swift + Xcode 开发环境搭建终极指南
开发语言·ios·swiftui·xcode·swift·苹果vision pro·swift5.6.3