SwiftUI:TextField 中的多颜色文本

Sha*_*aib 4 ios swift swiftui

我想为 TextField 中的文本更改两种不同的颜色。对于第一个单词,颜色为深灰色,对于第二个单词,颜色为浅灰色。是否可以?

TextField("Dumble Dore!", text: $username)
Run Code Online (Sandbox Code Playgroud)

use*_*ser 5

还有另一种方法只使用 SwiftUI 和我们手头上的东西:

Xcode:版本 12.5.1 (12E507)

struct ContentView: View {
    
    @State private var string: String = "Dumble Dore!"
    
    var body: some View {
        
        CustomTextFieldView(titleKey: "Enter your text here ...", dropIndex: 7, string: $string)
        
    }
    
}




struct CustomTextFieldView: View {
    
    let titleKey: LocalizedStringKey
    let dropIndex: Int
    @Binding var string: String
    
    var body: some View {
        
        HStack(spacing: 0.0) {
            
            Text(string.dropLast((string.count >= dropIndex) ? (string.count - dropIndex) : 0)).foregroundColor(Color(UIColor.darkGray)).lineLimit(1)
            
            Text(string.dropFirst(dropIndex)).foregroundColor(Color(UIColor.lightGray)).lineLimit(1)
            
            Spacer()
        }
        .overlay(TextField(titleKey, text: $string).foregroundColor(.clear), alignment: .topLeading)
        
    }
    
}
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述