SwiftUI极简教程28:TextEditor多行文本框的使用

简介: SwiftUI极简教程28:TextEditor多行文本框的使用

在本章中,你将学会使用TextEditor多行文本实现一个多行文本输入框。

image.png


iOS14中,苹果为SwiftUI框架引入了一个名为TextEditor的多行文本框组件,TextEditor文本框可以实现显示和编辑多行文本。

那么,本章我们就来了解下TextEditor多行文本框的使用。

首先,创建一个新项目,命名为SwiftUITextEditor


image.png

TextEditor多行文本框和TextField输入框的使用方法很类似,需要定义变量绑定内容。

然后,我们也可以像TextField输入框一样,给TextEditor多行文本框添加修饰符美化它。


struct ContentView: View {
    @State private var message = ""
    var body: some View {
        TextEditor(text: $message)
            .font(.title)
            .lineSpacing(20)    // 行距
            .autocapitalization(.words)
            .disableAutocorrection(true)
            .padding()
    }
}

image.png

如果我们要统计TextEditor多行文本框的输入字数时,这里引用一个TextEditor多行文本框的修饰符.onChange改变时,我们可以通过.onChange改变时的修饰符和Text文本,来实现TextEditor多行文本框字数的统计。


.onChange(of: message) { value in
        //代码块
}


我们先定义字数统计的初始值wordCount


@State private var wordCount: Int = 0


然后通过ZStack叠加视图将TextEditor多行文本框和Text文本包裹在一起,我们把wordCount字数统计放在右上角。

每当我们输入一个字符时,onChange修饰符中的代码就会被调用。

在闭包中,我们计算message中的单词总数,然后动态更新wordCount字数统计。


struct ContentView: View {
    @State private var message = ""
    @State private var wordCount: Int = 0
    var body: some View {
        ZStack(alignment: .topTrailing) {
            // 多行文本框
            TextEditor(text: $message)
                .font(.title)
                .lineSpacing(20)
                .autocapitalization(.words)
                .disableAutocorrection(true)
                .padding()
                //改变时
                .onChange(of: message) { _ in
                    let words = message.split { $0 == " " || $0.isNewline }
                    self.wordCount = words.count
                }
            // 字数统计
            Text("\(wordCount)")
                .font(.headline)
                .foregroundColor(.secondary)
                .padding(.trailing)
        }
    }
}


image.png

样式我们再美化一下,使用.overlay加个圆角边框。


.overlay(
    RoundedRectangle(cornerRadius: 8)
        .stroke(Color.gray, lineWidth: 1)
)

image.png

嗯,不错。

不过可惜的一点是,TextEditor多行文本框不像TextField输入框一样,可以直接加上placehoder注释文字,这需要我们自己实现。

也不难,我们可以通过判断message输入文字是否为空,或者wordCount字数统计是否为0来实现没有输入内容时显示placehoder注释文字。

image.png

完整代码如下:


struct ContentView: View {
    @State private var message = ""
    @State private var wordCount: Int = 0
    var body: some View {
        ZStack(alignment: .topLeading) {
            ZStack(alignment: .bottomTrailing) {
                // 多行文本框
                TextEditor(text: $message)
                    .font(.title3)
                    .lineSpacing(20)
                    .autocapitalization(.words)
                    .disableAutocorrection(true)
                    .padding()
                    .frame(minWidth: 0, maxWidth: .infinity, minHeight: 0, maxHeight: 180)
                    // 改变时
                    .onChange(of: message) { _ in
                        let words = message.split { $0 == " " || $0.isNewline }
                        self.wordCount = words.count
                    }
                // 字数统计
                Text("\(wordCount)")
                    .font(.headline)
                    .foregroundColor(.secondary)
                    .padding(.trailing)
                    .padding()
            }
            //边框
            .overlay(
                RoundedRectangle(cornerRadius: 8)
                    .stroke(Color.gray, lineWidth: 1)
            )
            // 注释文字
            if message.isEmpty {
                Text("请输入内容")
                    .foregroundColor(Color(UIColor.placeholderText))
                    .padding(15)
            }
        }
        .padding()
    }
}

快来动手试试吧!


相关文章
|
iOS开发
SwiftUI极简教程34:LazyVGrid垂直网格和LazyHGrid水平网格的使用
SwiftUI极简教程34:LazyVGrid垂直网格和LazyHGrid水平网格的使用
1991 0
SwiftUI极简教程34:LazyVGrid垂直网格和LazyHGrid水平网格的使用
|
存储 Swift
SwiftUI极简教程41:使用Segment、LazyVGrid和ImagePicker构建一个Logo生成器
在本章中,你将学会使用Segment分段器、LazyVGrid垂直网格、ImagePicker图片选择器构建一个Logo生成器。 在上一章中,我们完善了SearchBar搜索栏、TabView底部导航,还有做了一个Loading加载动作。最近突然有个想法,如果把色卡和图片进行组合,这不就是一个简单的Logo了吗?我能不能做个Logo生成器? 说干就干,我们继续完成App的相关内容。
862 0
SwiftUI极简教程41:使用Segment、LazyVGrid和ImagePicker构建一个Logo生成器
|
程序员 索引
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
1432 0
SwiftUI极简教程18:SwipeCard卡片滑动效果的使用(上)
|
存储 索引
SwiftUI极简教程19:SwipeCard卡片滑动效果的使用(下)
SwiftUI极简教程19:SwipeCard卡片滑动效果的使用(下)
845 0
SwiftUI极简教程19:SwipeCard卡片滑动效果的使用(下)
|
iOS开发
加载中,加载中......使用SwiftUI设计2种Loading动画
加载中,加载中......使用SwiftUI设计2种Loading动画
726 0
|
iOS开发 开发者 容器
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(二)(2)
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(二)
247 0
|
存储
SwiftUI极简教程40:构建SearchBar搜索栏和TabView底部导航
在本章中,你将学会构建Search搜索进行列表搜索和TabView底部导航。 在上一章节中,我们完成了一个简单的ColourAtla色卡App,接下来我们继续完善App的相关内容。
1117 0
SwiftUI极简教程40:构建SearchBar搜索栏和TabView底部导航
展开&收起,使用SwiftUI搭建一个侧滑展开页面交互
展开&收起,使用SwiftUI搭建一个侧滑展开页面交互
469 0
|
存储 人机交互 API
8个SwiftUI的小技巧让隔壁同事两眼放光,直呼太卷了
在日常的SwiftUI开发过程中,常常会出现一些“小BUG”让我们措手不及、头顶发凉。这些问题可能是由于我们自己不熟悉SwiftUI语法导致的,也有是SwiftUI本身自带的缺陷,毕竟是一个新兴语言。 那么本章就介绍一些SwiftUI开发的小技巧,帮助我们避避那些让我们头秃的坑。
1426 0
8个SwiftUI的小技巧让隔壁同事两眼放光,直呼太卷了
|
安全
SwiftUI—如何使视图充满整个屏幕
SwiftUI—如何使视图充满整个屏幕
1020 0
SwiftUI—如何使视图充满整个屏幕

热门文章

最新文章