工作中遇到一个案例,之前没有写过,今儿啃了半个下午硬是给写出来,灰常又成就感!当然对于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));
- }
-
- });
- })
然后介绍同页面下多个textarea实现案例
JavaScript Code复制内容到剪贴板
- function changeLength(obj,num){
- obj.on(\'keyup\',function(){
- var txtval = obj.val().length;
-
- var str = parseInt(600-txtval);
-
- if(str > 0 ){
- num.html(\'剩余可输入\'+str+\'字\');
- }else {
- num.html(\'剩余可输入0字\');
- obj.val(obj.val().substring(0, 600));
- }
-
- });
- }
- $(function(){
- 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复制内容到剪贴板
-
- 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中获取动态剩余字数的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持phpstudy。
本文地址:https://www.stayed.cn/item/26062
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我