当前位置: 首页 > article >正文

【uniapp】textarea maxlength字数计算不准确的问题

背景

一个非常常见的功能, 多行文本输入框内增加maxlength最大字数限制500字。但是当我们多行输入并且有换行时,比如到493字时却无论如何输入不了。是因为maxlength计算时,把换行也计算进去了,并且换行符 \n 被计算为 2 个字符textarea 可能会将换行符 \n 计算为2个字符,导致字数限制比预期更早达到上限。
在这里插入图片描述

解决办法

监听 input 事件,手动计算实际字符数
你可以使用 @input 监听输入事件,手动去掉 换行符和特殊字符 之后再计算长度,确保用户可以真正输入 500 个字符。

<template>
  <textarea 
    v-model="text" 
    :maxlength="500" 
    @input="handleInput"
    placeholder="请输入内容"
  ></textarea>
  <p>{{ text.length }}/500</p>
</template>

<script>
export default {
  data() {
    return {
      text: ""
    };
  },
  methods: {
    handleInput(event) {
      let value = event.detail.value;
      // 处理换行符问题,确保换行符不多计算
      value = value.replace(/\r\n/g, "\n"); // 统一换行符
      value = value.replace(/\n/g, " "); // 换行符改为空格,不占字符

      if (value.length > 500) {
        this.text = value.substring(0, 500);
      } else {
        this.text = value;
      }
    }
  }
};
</script>

完美解决~~


http://www.kler.cn/a/583037.html

相关文章:

  • Go Context深度剖析
  • doris:Elasticsearch
  • 【K8s】使用Kubernetes的resources字段中的requests和limits字段控制Pod资源使用
  • uni-app如何发布项目为app_2025
  • Linux进程基础知识
  • 在线Doc/Docx转换为PDF格式 超快速转换的一款办公软件 文档快速转换 在线转换免费转换办公软件
  • linux和windows之间的复制
  • Github 2025-03-11 Python开源项目日报Top10
  • jira操作笔记
  • C++相关数据结构的API调用
  • 算力服务器主要是指什么?
  • 基于SpringBoot的七彩云南文化旅游网站设计与实现(源码+SQL脚本+LW+部署讲解等)
  • 数组总和 (leetcode 40
  • css 知识点整理
  • Qt 数据库操作(Sqlite)
  • Java虚拟机之垃圾收集(一)
  • idea超级AI插件,让 AI 为 Java 工程师
  • 基于PyTorch的深度学习6——可视化工具Tensorboard
  • 无人机第三方安全风险评估技术详解
  • 从0开始的操作系统手搓教程45——实现exec