iOS(Swift) TextField限制输入文本的长度(不是字数)

最近做项目有一个特殊需求,就是需要限制一个TextField的输入文本的长度在一定范围内(注意,不是字数),上网查了一圈没有找到类似文章,这里把我的方法写进来,mark一下:

1、对TextField添加监听函数:

1
textField . addTarget ( self action "textFieldTextDidChange:" forControlEvents UIControlEvents . EditingChanged )

2、在输入内容变化时进行处理:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
func  textFieldTextDidChange ( textField : UITextField ) {
     if  let  _  textField . text  {
         if  let  positionRange  textField . markedTextRange  {
             if  let  _  textField . positionFromPosition ( positionRange . start offset 0 ) {
                 //正在使用拼音,不进行校验
             else  {
                 //不在使用拼音,进行校验
                 self . checkTextFieldLengthAndModify ( textField )
             }
         else  {
             //不在使用拼音,进行校验
             self . checkTextFieldLengthAndModify ( textField )
         }
     }
}

3、实现校验方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
//检查输入框的文字是否超长,如果超出长度则做截短
func  checkTextFieldLengthAndModify ( textField : UITextField ) {
     if  let  text  textField . text  {
         if  self . checkTextFielLength ( textField str text ) {
             //长度正常,不处理
         else  {
             //超出长度,开始处理
             self . view . makeToastCenter ( "输入文字过长" )
             
             let  len  text . length
             let  txt  text  as  NSString
             if  len  >  0  {
                 //进行截短,看是否超长,如果不超长,则继续截短,直到不超长为止
                 //Exp:
                 //apple
                 //appl
                 //app
                 for  var  i  len - 1 i  > 0 i -- {
                     let  txt_s  txt . substringToIndex ( i )
                     //print("txt_s : \(txt_s)")
                     if  self . checkTextFielLength ( textField str txt_s ) {
                         //就截取到这了
                         textField . text  txt_s
                         break
                     else  {
                         //继续截取
                     }
                 }
             }
         }
     }
}

4、实现checkTextFielLength,判断文字是否超出输入框长度

1
2
3
4
5
6
7
8
func  checkTextFielLength ( textField UITextField str NSString ) - >  Bool  {
     let  rect  str . boundingRectWithSize ( CGSizeMake ( CGFloat ( MAXFLOAT ),  CGFloat ( MAXFLOAT )),  options : . UsesLineFragmentOrigin attributes textField . defaultTextAttributes context nil )
     if  rect . width  >  textField . width  {
         return  false
     else  {
         return  true
     }
}

 

这里的长度限制是根据UITextField的长度来限制的,你也可以根据自己的需求来设定限制的长度。

 

转载于:https://www.cnblogs.com/Hakim/p/6513495.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Jetpack Compose 中,你可以使用 `TextField` 组件来实现限制字数的功能。你可以通过为 `TextField` 添加一个 `VisualTransformation` 来实现这个限制。 首先,你需要创建一个 `VisualTransformation`,它会修改输入文本。在这个 `VisualTransformation` 中,你可以检查输入文本长度,并根据需要进行截断。 下面是一个示例代码: ```kotlin @Composable fun LimitedTextField( maxLength: Int, text: String, onTextChanged: (String) -> Unit ) { val transformedText = remember(text) { // 创建 VisualTransformation,限制输入文本长度 VisualTransformation { val truncatedText = it.text.take(maxLength) if (truncatedText != it.text) { // 如果文本被截断,需要更新输入框中的文本 onTextChanged(truncatedText) } TransformationResult(truncatedText) } } TextField( value = text, onValueChange = onTextChanged, visualTransformation = transformedText ) } ``` 在上面的例子中,`LimitedTextField` 是一个自定义的组件,它接受 `maxLength` 参数来指定最大字数限制。`text` 参数是当前输入文本内容,`onTextChanged` 是一个回调函数,用于在文本发生变化时更新文本内容。 在 `LimitedTextField` 中,我们使用了 `remember` 函数来创建一个 `VisualTransformation`。每当 `text` 发生变化时,`remember` 函数会重新计算 `VisualTransformation`,确保它与新的 `text` 值保持同步。 然后,我们将这个 `VisualTransformation` 应用到 `TextField` 组件中,限制输入文本长度。当文本被截断时,会触发 `onTextChanged` 回调函数来更新输入框中的文本。 使用这个 `LimitedTextField` 组件,你可以在 Compose 中实现限制字数文本输入框。 ```kotlin @Composable fun MyScreen() { var text by remember { mutableStateOf("") } Column { LimitedTextField( maxLength = 10, text = text, onTextChanged = { newText -> text = newText } ) Text("当前字数: ${text.length}") } } ``` 在上面的示例中,我们创建了一个具有最大长度为 10 的限制输入框,并在下方显示当前输入字数。你可以根据需要调整 `maxLength` 的值来限制不同的字数

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值