Mac OS Swift UI 如何在Swift UI中灵活的使用NSTextField

效果

输入框a跟随b的内容而变化,输入框b也跟随a的内容变化而变化。
在这里插入图片描述

创建一个Swift UI中的输入框

创建一个输入框,并绑定一个text内容

struct ContentView: View {
    @State var text = ""
    var body: some View {
        VStack {
            Text("Custom TextField")
            Group {
                TextField("请输入文字", text: self.$text).padding()
            }
        }.frame(width: 300, height: 400, alignment: .center)
    }
}

在这里插入图片描述

自定义一个NSTextField

绑定一个内容属性

@Binding var text: String

重写makeNSView

func makeNSView(context: NSViewRepresentableContext<MyTextField>) -> NSTextField {
    //新建一个NSTextField
    let textField = NSTextField()
    textField.focusRingType = .none
    textField.isBordered = false
    textField.drawsBackground = true
    **重要:**绑定代理
    textField.delegate = context.coordinator
    return textField
}

重写updateNSView

func updateNSView(_ nsView: NSTextField, context: NSViewRepresentableContext<MyTextField>) {
        nsView.stringValue = text
    }

代理绑定

func makeCoordinator() -> MyTextField.Coordinator {
        Coordinator(parent: self)
    }
    
    class Coordinator: NSObject, NSTextFieldDelegate  {
        let parent: MyTextField
        init(parent: MyTextField) {
            self.parent = parent
        }
        func controlTextDidChange(_ obj: Notification) {
            let textField = obj.object as! NSTextField
            parent.text = textField.stringValue
        }
    }

加入contentView

struct ContentView: View {
    @State var text = ""
    var body: some View {
        VStack {
            Text("Custom TextField")
            Group {
                TextField("请输入文字", text: self.$text).padding()
                MyTextField(text: self.$text).padding()
            }
        }.frame(width: 300, height: 400, alignment: .center)
    }
}

END

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄权浩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值