textField控制字数(字符16个)

[_nameEditTF addTarget:self action:@selector(valueChanged:) forControlEvents:UIControlEventEditingChanged];




- (void)valueChanged:(id)sender {

    int strlength = 0;

    char* p = (char*)[_nameEditTF.text cStringUsingEncoding:NSUnicodeStringEncoding];

    

    for (int i=0 ; i<[_nameEditTF.text lengthOfBytesUsingEncoding:NSUnicodeStringEncoding] ;i++) {

        if (*p) {

            p++;

            strlength++;

        }

        else {

            p++;

        }

    }

    self.longthStr = [_nameEditTF.text mutableCopy];

    //中文一个字符 英文两个字符

    if ((strlength+1)/2 == 8) {

        _index = [_nameEditTF.text length];

    }


    if ((strlength+1)/2 > 8) {

        if (([_longthStr length] >= _index) && (_index > 6)) {

            _nameEditTF.text = [_longthStr substringToIndex:_index];

        }else if (_index == 0) {

            _nameEditTF.text = [_longthStr substringToIndex:8];

        }

    }

}






- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string

{

    int strlength = 0;

    char* p = (char*)[textField.text cStringUsingEncoding:NSUnicodeStringEncoding];

    for (int i=0 ; i<[textField.text lengthOfBytesUsingEncoding:NSUnicodeStringEncoding] ;i++) {

        if (*p) {

            p++;

            strlength++;

        }

        else {

            p++;

        }

    }

    if ((strlength+1)/2 >= 8) {

        if ([string isEqualToString:@""]) {

            //可以删除

            return YES;

        }

        return NO;

    }

    return YES;

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
资源包主要包含以下内容: ASP项目源码:每个资源包中都包含完整的ASP项目源码,这些源码采用了经典的ASP技术开发,结构清晰、注释详细,帮助用户轻松理解整个项目的逻辑和实现方式。通过这些源码,用户可以学习到ASP的基本语法、服务器端脚本编写方法、数据库操作、用户权限管理等关键技术。 数据库设计文件:为了方便用户更好地理解系统的后台逻辑,每个项目中都附带了完整的数据库设计文件。这些文件通常包括数据库结构图、数据表设计文档,以及示例数据SQL脚本。用户可以通过这些文件快速搭建项目所需的数据库环境,并了解各个数据表之间的关系和作用。 详细的开发文档:每个资源包都附有详细的开发文档,文档内容包括项目背景介绍、功能模块说明、系统流程图、用户界面设计以及关键代码解析等。这些文档为用户提供了深入的学习材料,使得即便是从零开始的开发者也能逐步掌握项目开发的全过程。 项目演示与使用指南:为帮助用户更好地理解和使用这些ASP项目,每个资源包中都包含项目的演示文件和使用指南。演示文件通常以视频或图文形式展示项目的主要功能和操作流程,使用指南则详细说明了如何配置开发环境、部署项目以及常见问题的解决方法。 毕业设计参考:对于正在准备毕业设计的学生来说,这些资源包是绝佳的参考材料。每个项目不仅功能完善、结构清晰,还符合常见的毕业设计要求和标准。通过这些项目,学生可以学习到如何从零开始构建一个完整的Web系统,并积累丰富的项目经验。
在 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` 的值来限制不同的字数
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值