DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 基於JS實現textarea中獲取動態剩余字數的方法
基於JS實現textarea中獲取動態剩余字數的方法
編輯:關於JavaScript     

案例介紹:我們常見到有的網站有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中獲取動態剩余字數的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved