首页 web前端 js教程 在js中如何实现监控文本框输入字数(详细教程)

在js中如何实现监控文本框输入字数(详细教程)

Jun 11, 2018 pm 03:04 PM
实时监控 文本框

下面我就为大家分享一篇实时监控文本框输入字数的实例代码,具有很好的参考价值,希望对大家有所帮助。

需求:实时监控文本输入框的字数,并加以限制

1、实时监控当前输入字数,直接使用onkeyup事件方法,给输入框加maxlength属性限制长度。如:

<p>
 <textarea id="txt" maxlength="10"></textarea>
 <p><span id="txtNum">0</span>/10</p>
 </p>
登录后复制
var txt = document.getElementById("txt");
 var txtNum = document.getElementById("txtNum");
 txt.addEventListener("keyup", function(){
 txtNum.textContent = txt.value.length;
 })
登录后复制

此时已可以完成基本的监控功能,存在的问题:当输入英文时正常,但输入中文时,监控的数字会随拼音长度而变化。

2、解决方法:

compositionstart 事件触发于一段文字的输入之前(类似于 keydown 事件,但是该事件仅在若干可见字符的输入之前,而这些可见字符的输入可能需要一连串的键盘操作、语音识别或者点击输入法的备选词)。

compositionend 就是对应的就是一段文字输入的事件。

这两个属性有点类似于“开关”,如:开始进行中文输入的拼音时开关打开,不在改变监测得到的长度数值,完整输入一个或是一串文字后,开关关闭,得到监测的数值长度。

var txt = document.getElementById("txt");
 var txtNum = document.getElementById("txtNum");
 var sw = false; //定义关闭的开关
 txt.addEventListener("keyup", function(){
 if(sw == false){
  countTxt();
 }
 });
 txt.addEventListener("compositionstart", function(){
 sw = true;
 });
 txt.addEventListener("compositionend", function(){
 sw = false;
 countTxt();
 });
 function countTxt(){ //计数函数
 if(sw == false){ //只有开关关闭时,才赋值
  txtNum.textContent = txt.value.length;
 }
 }
登录后复制

在vue中的写法:

template:

<textarea name="suggestions-text" id="textarea" cols="30" rows="10" maxlength="300" v-on:keyup="write()" v-on:compositionstart="importStart()" v-on:compositionend="importEnd()" v-model="textContent"></textarea>
<p class="counterNum">{{conterNum}}/300</p>
登录后复制

data:

textContent: &#39;&#39;,
conterNum: 0,
chnIpt: false,
登录后复制

methods:

write() {
 let self = this;
 if (self.chnIpt == false) {
 self.conterNum = self.textContent.length;
 }
},
importStart() {
 this.chnIpt = true;
},
importEnd() {
 this.chnIpt = false;
 this.write();
}
登录后复制

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

使用axios封装fetch方法和调用

在JS中Map和ForEach的区别有哪些?

在vue中如何实现页面加载进度条组件

javascript该如何实现获取日期段内每天不同的价格

在vue中如何实现图片loading组件

为什么Node.js会成为Web应用开发?

在javascript中如何实现最长公共子序列

以上是在js中如何实现监控文本框输入字数(详细教程)的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

OneNote如何设置图片为背景 OneNote如何设置图片为背景 May 14, 2023 am 11:16 AM

Onenote是Microsoft提供的最好的笔记工具之一。结合Outlook和MSTeams,Onenote可以成为提高工作和个人创意工作效率的强大组合。我们必须以不同的格式做笔记,这可能不仅仅是把事情写下来。有时我们需要从不同来源复制图像并在日常工作中进行一些编辑。如果知道如何应用更改,则粘贴在Onenote上的图像可以发挥很大作用。您在使用Onenote时是否遇到过粘贴在Onenote上的图像无法让您轻松工作的问题?本文将着眼于在Onenote上有效地使用图像。我们可

如何隐藏文本直到在 Powerpoint 中单击 如何隐藏文本直到在 Powerpoint 中单击 Apr 14, 2023 pm 04:40 PM

如何在 PowerPoint 中的任何点击之前隐藏文本如果您希望在单击 PowerPoint 幻灯片上的任意位置时显示文本,那么设置起来既快速又容易。要在 PowerPoint 中单击任何按钮之前隐藏文本:打开您的 PowerPoint 文档,然后单击“插入 ”菜单。单击新幻灯片。选择空白或其他预设之一。仍然在插入菜单中,单击文本框。在幻灯片上拖出一个文本框。单击文本框并输入您

使用Gin框架实现实时监控和报警功能 使用Gin框架实现实时监控和报警功能 Jun 22, 2023 pm 06:22 PM

Gin是一个轻量级的Web框架,它采用了Go语言的协程和高速路由处理能力,能够快速地开发高性能的Web应用程序。在本文中,我们将探讨如何使用Gin框架实现实时监控和报警功能。监控和报警是现代软件开发的重要部分。在一个大型系统中,可能会有数千个进程、数百个服务器、数以百万计的用户。这些系统产生的数据量常常是惊人的,因此需要一种能够快速处理这些数据并及时警告系统

WebSocket与JavaScript:实现实时监控系统的关键技术 WebSocket与JavaScript:实现实时监控系统的关键技术 Dec 17, 2023 pm 05:30 PM

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何在 Word 中制作日历 如何在 Word 中制作日历 Apr 25, 2023 pm 02:34 PM

如何使用表格在Word中制作日历如果您想创建一个完全符合您的规范的日历,您可以使用Word中的表格从头开始做所有事情。这使您可以为日历设计所需的确切布局。在Word中使用表格创建日历:打开一个新的Word文档。按Enter几次,将光标向下移动到页面。单击插入 菜单。在功能区中,单击表格图标。单击并按住左上角的方块并拖出一个7×6的表格。在第一行填写星期几。使用另一个日历作为参考填写月份中的日期。突出显示当前月份之外的任何日期。在主菜单中,单击文本颜色图标并选择灰色。对当前月份以

如何实时监控MySQL连接数? 如何实时监控MySQL连接数? Jun 29, 2023 am 08:31 AM

如何实时监控MySQL连接数?MySQL是一种广泛使用的关系型数据库管理系统,用于存储和管理大量的数据。在高并发的情况下,MySQL的连接数是关键指标之一,能够直接影响系统的性能和稳定性。因此,实时监控MySQL连接数对于系统运维和性能优化是必不可少的。本文将介绍一些常用的方法和工具,来实时监控MySQL连接数以及相应的解决方案。MySQL的内置状态变量My

如何配置CentOS系统以防范恶意软件和病毒的入侵 如何配置CentOS系统以防范恶意软件和病毒的入侵 Jul 05, 2023 am 10:25 AM

如何配置CentOS系统以防范恶意软件和病毒的入侵引言:在当今数字化时代,计算机和互联网已经成为人们日常生活中不可或缺的一部分。然而,随着互联网的普及和计算机技术的不断进步,网络安全问题也日益严峻。恶意软件和病毒的入侵给我们的个人信息安全和计算机系统稳定性带来了极大的威胁。为了能够更好地保护我们的计算机系统免受恶意软件和病毒的入侵,本文将介绍如何配置Cent

如何使用Go语言和Redis实现实时监控系统 如何使用Go语言和Redis实现实时监控系统 Oct 27, 2023 pm 12:48 PM

如何使用Go语言和Redis实现实时监控系统引言:实时监控系统在今天的软件开发中扮演着重要的角色。它能够及时收集、分析和展示系统各项指标,帮助我们了解当前系统的运行状况,并且对系统进行及时调整和优化。本文将介绍如何使用Go语言和Redis实现一个简单的实时监控系统,并且提供具体的代码示例。一、什么是实时监控系统实时监控系统是指能够实时收集和展

See all articles