如何使用HTML和Vue实现数字自动换行和去尾数的textarea?

霞舞
发布: 2025-03-19 09:58:14
原创
734人浏览过

如何使用html和vue实现数字自动换行和去尾数的textarea?

Vue.js与HTML结合实现数字自动换行和去零处理的textarea

本文介绍如何构建一个特殊的textarea,实现纯数字输入,长数字自动换行,并自动去除小数点后多余的零。例如,输入123456789.234000,显示效果为123456\n789.2\n34,但底层数据仍保留原始值123456789.234000。

我们将使用Vue.js的ref来管理数据。定义两个变量:textarea_number_data存储原始数据,textarea_number用于显示格式化后的数据。

首先,在Vue组件中,我们使用ref定义数据变量:

<script>
import { ref } from 'vue';

export default {
  setup() {
    const textarea_number_data = ref('');
    const textarea_number = ref('');

    const formatNumber = (value) => {
      // 去除非数字和小数点,保留一个小数点
      let cleanedValue = value.replace(/[^\d.]/g, '').replace(/\.(?=.*\.)/g, '');
      // 去除小数点后多余的零
      cleanedValue = parseFloat(cleanedValue).toFixed(cleanedValue.includes('.') ? 3 : 0);  // 保留三位小数,整数则不保留
      textarea_number_data.value = cleanedValue;

      // 每六位数字换行
      textarea_number.value = cleanedValue.replace(/(\d{6})(?=\d)/g, '$1\n');
    };

    return { textarea_number_data, textarea_number, formatNumber };
  },
};
</script>
登录后复制

然后,在模板中绑定数据和事件:

立即学习前端免费学习笔记(深入)”;

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人
<template>
  <div>
    <textarea v-model="textarea_number" @input="formatNumber(textarea_number)" placeholder="请输入数字"></textarea>
    <p>原始数据: {{ textarea_number_data }}</p>
  </div>
</template>
登录后复制

formatNumber函数负责数据处理:首先使用正则表达式清除无效字符,确保只有一个小数点;然后使用parseFloattoFixed处理小数位,去除多余的零;最后,使用正则表达式每六位数字添加换行符。 @input事件监听textarea的输入变化,实时调用formatNumber函数进行格式化。

通过这个方法,我们实现了数字的自动换行和尾数零的去除,同时确保原始数据完整性。 用户输入的数据在textarea_number_data中以原始格式保存,而在textarea中显示格式化后的结果。 这个方案比仅使用正则表达式更健壮,因为它处理了小数点后多余零的情况。

以上就是如何使用HTML和Vue实现数字自动换行和去尾数的textarea?的详细内容,更多请关注php中文网其它相关文章!

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号