工作中遇到一个案例,之前没有写过,今儿啃了半个下午硬是给写出来,灰常又成就感!当然对于js大牛来说这根本不算啥,但是对于我自己的js能力又向前迈出一小步。
案例介绍:我们常见到有的网站有textarea文本框,当你输入的时候,下面有文字提示还能输入多少个字,今天就是要实现这个功能。当然,由于一个页面有好几个textarea,所以使用单个js逻辑进行控制是不行的,得小小的进行封装一下。当然我的封装还有缺漏,但是基本功能是实现了。
首先介绍下单个textarea实现案例
html部分:
XML/HTML Code复制内容到剪贴板- <textarea id="text_txt1"></textarea>
 - <span id ="num_txt1">剩余可输入600字</span>
 
js部分:
JavaScript Code复制内容到剪贴板- $(function(){
 - $('#text_txt1').on('keyup',function(){
 - var txtval = $('#text_txt1').val().length;
 - console.log(txtval);
 - var str = parseInt(600-txtval);
 - console.log(str);
 - if(str > 0 ){
 - $('#num_txt1').html('剩余可输入'+str+'字');
 - }else{
 - $('#num_txt1').html('剩余可输入0字');
 - $('#text_txt1').val($('#text_txt1').val().substring(0,600)); //这里意思是当里面的文字小于等于0的时候,那么字数不能再增加,只能是600个字
 - }
 - //console.log($('#num_txt').html(str));
 - });
 - })
 
然后介绍同页面下多个textarea实现案例
JavaScript Code复制内容到剪贴板- function changeLength(obj,num){
 - obj.on('keyup',function(){
 - var txtval = obj.val().length;
 - //console.log(txtval);
 - var str = parseInt(600-txtval);
 - //console.log(str);
 - if(str > 0 ){
 - num.html('剩余可输入'+str+'字');
 - }else {
 - num.html('剩余可输入0字');
 - obj.val(obj.val().substring(0, 600));
 - }
 - //console.log($('#num_txt').html(str));
 - });
 - }
 - $(function(){ //我这里有四个,所以调用4次
 - changeLength($('#text_txt1'),$('#num_txt1'));
 - changeLength($('#text_txt2'),$('#num_txt2'));
 - changeLength($('#text_txt3'),$('#num_txt3'));
 - changeLength($('#text_txt4'),$('#num_txt4'));
 - });
 
当然这里面实际上要求的字数也可以封装在函数内部,不过我就不封装了。这样就实现了当输入文字的时候,span内部会自动显示剩余字数,当输入值达最高值时,显示剩余字数为0,且无法在新填入内容。当删除文字的时候,span又能动态获取剩余字数。
下面上下别人的代码,这次多少也借鉴了别人的写法
html:
XML/HTML Code复制内容到剪贴板- <div class="family_v2">
 - <p class="nickname_v2">简介:</p>
 - <textarea id="content" name="sign" style="height:60px;overflow-y: hidden;"
 - onkeyup="changeLength(this,60)" class="nicknameBox_v2 brief_box_v2">
 - </textarea>
 - <div class="limit_num_v2">
 - <h3>60</h3>
 - </div>
 - </div>
 
js:
JavaScript Code复制内容到剪贴板- //验证textarea的长度
 - function changeLength(obj,lg){
 - var len = $(obj).val();
 - $(obj).next().find("h3").text(lg-len.length);
 - if(len.length>=lg){
 - $(obj).next().find("h3").text(0);
 - $(obj).val(len.substring(0,lg));
 - }
 - }
 
以上这篇如何实现textarea中获取动态剩余字数的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
                                    标签:
                                        
                            textarea,剩余字数
                                免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
                                如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
                            
                        白云城资源网 Copyright www.dyhadc.com
                        暂无“如何实现textarea中获取动态剩余字数的方法”评论...
                                    稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2025年11月04日
                                2025年11月04日
                    - 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
 - 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
 - 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
 - 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
 - 群星《2024好听新歌42》AI调整音效【WAV分轨】
 - 王思雨-《思念陪着鸿雁飞》WAV
 - 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
 - 李健《无时无刻》[WAV+CUE][590M]
 - 陈奕迅《酝酿》[WAV分轨][502M]
 - 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
 - 群星《吉他王(黑胶CD)》[WAV+CUE]
 - 齐秦《穿乐(穿越)》[WAV+CUE]
 - 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
 - 邝美云《邝美云精装歌集》[DSF][1.6G]
 - 吕方《爱一回伤一回》[WAV+CUE][454M]