我想要一些功能,如果我写的话
<textarea maxlength="50"></textarea> <textarea maxlength="150"></textarea> <textarea maxlength="250"></textarea>
它将自动将maxlength施加在textArea上。如果可能,请不要在jQuery中提供解决方案。
注意:如果我做这样的事情,可以这样做:
<textarea onkeypress="return imposeMaxLength(event, this, 110);" rows="4" cols="50"> function imposeMaxLength(Event, Object, MaxLen) { return (Object.value.length <= MaxLen)||(Event.keyCode == 8 ||Event.keyCode==46||(Event.keyCode>=35&&Event.keyCode<=40)) }
复制自: 在HTML textarea上模拟HTML输入“maxlength”属性的最佳方法是什么?
但是关键是我不想每次声明textArea时都编写onKeyPress和onKeyUp。
window.onload = function() { var txts = document.getElementsByTagName(‘TEXTAREA’);
for(var i = 0, l = txts.length; i < l; i++) { if(/^[0-9]+$/.test(txts[i].getAttribute("maxlength"))) { var func = function() { var len = parseInt(this.getAttribute("maxlength"), 10); if(this.value.length > len) { alert('Maximum length exceeded: ' + len); this.value = this.value.substr(0, len); return false; } } txts[i].onkeyup = func; txts[i].onblur = func; } }; }