SwiftUI List中的TextField

在SwiftUI开发中,使用List包裹TextField时遇到的问题及解决方法。当尝试在List中动态添加TextField并通过ForEach创建时,会遇到需要遵守Identifiable协议的警告。正确做法是为ForEach提供明确的id,或者升级到SwiftUI 3.0使用更简洁的语法。
摘要由CSDN通过智能技术生成

开发环境:XCode 12.5.1 、MacOS 11.5.1、IOS 14.0

实际开发过程中,会有用List包裹一些TextFiled的情况,我们可以写如下代码实现:

struct ListAndTextField: View {
    
    @State var players = ["Todi", "Messi", "Nimar"]

    var body: some View {
        VStack {
            List(0..<players.count) { index in
                TextField(players[index], text: $players[index])
            }
        }.padding()
    }
}

运行,看起来没有问题。如果我们想增加一个按钮,每次点击增加一个TextField

struct ListAndTextField: View {
    
    @State var players = ["Todi", "Messi", "Nimar"]

    var body: some View {
        VStack {
            List(0..<players.count) { index in
                TextField(players[index], text: $players[index])
            }
            
            Button(action: {
                self.players.append("ne
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值