案例介紹:我們常見到有的網站有textarea文本框,當你輸入的時候,下面有文字提示還能輸入多少個字,今天就是要實現這個功能。當然,由于一個頁面有好幾個textarea,所以使用單個js邏輯進行控制是不行的,得小小的進行封裝一下。當然我的封裝還有缺漏,但是基本功能是實現了。
首先介紹下單個textarea實現案例
html部分:
<textarea id="text_txt1"></textarea><span id ="num_txt1">剩余可輸入600字</span>
js部分:
$(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實現案例
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:
<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:
//驗證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));}}
以上所述是小編給大家介紹的基于JS實現textarea中獲取動態剩余字數的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答