私が書くなら、いくつかの機能を持ちたい
<textarea maxlength="50"></textarea>
<textarea maxlength="150"></textarea>
<textarea maxlength="250"></textarea>
textAreaにmaxlengthが自動的に課されます。可能であれば、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;
}
};
}
JQueryを避けたいと思っていますが、ソリューションにはJavaScriptが必要なので、このソリューション(jQuery 1.4を使用)は最も簡潔で堅牢です。
インスピレーションを受けていますが、Dana Woodmanの答えに対する改善:
その答えからの変更は次のとおりです:簡素化されたより一般的な、jQuery.liveを使用し、長さがOKの場合はvalを設定しません(IEでの矢印キーの動作、およびIEでの顕著な高速化につながります):
// Get all textareas that have a "maxlength" property. Now, and when later adding HTML using jQuery-scripting:
$('textarea[maxlength]').live('keyup blur', function() {
// Store the maxlength and value of the field.
var maxlength = $(this).attr('maxlength');
var val = $(this).val();
// Trim the field if it has content over the maxlength.
if (val.length > maxlength) {
$(this).val(val.slice(0, maxlength));
}
});
編集: jQuery 1.7 + のバージョンを更新し、on
の代わりにlive
を使用
// Get all textareas that have a "maxlength" property. Now, and when later adding HTML using jQuery-scripting:
$('textarea[maxlength]').on('keyup blur', function() {
// Store the maxlength and value of the field.
var maxlength = $(this).attr('maxlength');
var val = $(this).val();
// Trim the field if it has content over the maxlength.
if (val.length > maxlength) {
$(this).val(val.slice(0, maxlength));
}
});
更新少し堅牢であるため、代わりに.live()
を使用してEirikのソリューションを使用してください。
JQueryを使用していないソリューションが必要でしたが、Googleでこのページを見つけてjQuery風のソリューションを探している人のために追加したいと思いました。
$(function() {
// Get all textareas that have a "maxlength" property.
$('textarea[maxlength]').each(function() {
// Store the jQuery object to be more efficient...
var $textarea = $(this);
// Store the maxlength and value of the field.
var maxlength = $textarea.attr('maxlength');
var val = $textarea.val();
// Trim the field if it has content over the maxlength.
$textarea.val(val.slice(0, maxlength));
// Bind the trimming behavior to the "keyup" event.
$textarea.bind('keyup', function() {
$textarea.val($textarea.val().slice(0, maxlength));
});
});
});
Google社員に役立つことを願っています...
HTML5は、次のようにmaxlength
属性をtextarea
要素に追加します。
<!DOCTYPE html>
<html>
<body>
<form action="processForm.php" action="post">
<label for="story">Tell me your story:</label><br>
<textarea id="story" maxlength="100"></textarea>
<input type="submit" value="Submit">
</form>
</body>
</html>
現在、これはChrome 13、FF 5、およびSafari 5でサポートされています。当然のことながら、これはIE 9でサポートされていません(Win 7でテスト済み)。
このソリューションは、テキストの中央の文字が追加されたときに最後の文字が削除されるIEの問題を回避します。また、他のブラウザーでも正常に機能します。
$("textarea[maxlength]").keydown( function(e) {
var key = e.which; // backspace = 8, delete = 46, arrows = 37,38,39,40
if ( ( key >= 37 && key <= 40 ) || key == 8 || key == 46 ) return;
return $(this).val().length < $(this).attr( "maxlength" );
});
その後、フォームの検証では、ユーザーがtextareaの最大長を超えるテキストを貼り付けた(IEでのみ問題と思われる)問題を処理します。
これは、私が自分のサイトで使用しているコードの一部です。 残りの文字数をユーザーに表示するように改善されました。
(jQueryを要求しなかったOPに再び申し訳ありません。しかし、真剣に、最近jQueryを使用していないのは誰ですか?)
$(function() {
// Get all textareas that have a "maxlength" property.
$("textarea[maxlength]").each(function() {
// Store the jQuery object to be more efficient...
var $textarea = $(this);
// Store the maxlength and value of the field
var maxlength = $textarea.attr("maxlength");
// Add a DIV to display remaining characters to user
$textarea.after($("<div>").addClass("charsRemaining"));
// Bind the trimming behavior to the "keyup" & "blur" events (to handle mouse-based paste)
$textarea.on("keyup blur", function(event) {
// Fix OS-specific line-returns to do an accurate count
var val = $textarea.val().replace(/\r\n|\r|\n/g, "\r\n").slice(0, maxlength);
$textarea.val(val);
// Display updated count to user
$textarea.next(".charsRemaining").html(maxlength - val.length + " characters remaining");
}).trigger("blur");
});
});
国際的なマルチバイト文字でテストされていないので、それらが正確にどのように機能するのかわかりません
Maxlength属性は、Internet Explorer 10、Firefox、Chrome、およびSafariでサポートされています。
注:
<textarea>
タグのmaxlength属性は、Internet Explorer 9以前のバージョンまたはOperaではサポートされていません。
from HTML maxlength Attribute w3schools.com
IE8以前のバージョンでは、次を使用する必要があります
//only call this function in IE
function maxLengthLimit($textarea){
var maxlength = parseInt($textarea.attr("maxlength"));
//in IE7,maxlength attribute can't be got,I don't know why...
if($.browser.version=="7.0"){
maxlength = parseInt($textarea.attr("length"));
}
$textarea.bind("keyup blur",function(){
if(this.value.length>maxlength){
this.value=this.value.substr(0,maxlength);
}
});
}
追伸.
<input>
タグのmaxlength属性は、すべての主要なブラウザーでサポートされています。
また、次のイベントを追加して、テキストエリアへの貼り付けを処理します。
...
txts[i].onkeyup = function() {
...
}
txts[i].paste = function() {
var len = parseInt(this.getAttribute("maxlength"), 10);
if (this.value.length + window.clipboardData.getData("Text").length > len) {
alert('Maximum length exceeded: ' + len);
this.value = this.value.substr(0, len);
return false;
}
}
...
JQueryを使用して簡単かつ明確にすることができます
JSFiddle DEMO
<textarea id="ta" max="10"></textarea>
<script>
$("#ta").keypress(function(e){
var k = e.which==0 ? e.keyCode : e.which;
//alert(k);
if(k==8 || k==37 || k==39 || k==46) return true;
var text = $(this).val();
var maxlength = $(this).attr("max");
if(text.length >= maxlength) {
return false;
}
return true;
});
</script>
Firefox
、Google Chrome
、およびOpera
でテストされています
テキストエリアの値をトリミングするよりも優れたソリューションです。
$('textarea[maxlength]').live('keypress', function(e) {
var maxlength = $(this).attr('maxlength');
var val = $(this).val();
if (val.length > maxlength) {
return false;
}
});
最近maxlength
にtextarea
動作を実装し、この質問で説明されている問題に遭遇しました: Chromeはtextlengthでmaxlength属性を持つ文字を間違ってカウントします 。
したがって、ここにリストされているすべての実装は、ほとんどバグがありません。この問題を解決するには、.length
の前に.replace(/(\r\n|\n|\r)/g, "11")
を追加します。そして、文字列をカットするときにそれを念頭に置いた。
私はこのようなもので終わった:
var maxlength = el.attr("maxlength");
var val = el.val();
var length = val.length;
var realLength = val.replace(/(\r\n|\n|\r)/g, "11").length;
if (realLength > maxlength) {
el.val(val.slice(0, maxlength - (realLength - length)));
}
問題が完全に解決するかどうかはわかりませんが、今のところはうまくいきます。
このコード例を使用してみてください。
$("#TextAreaID1").bind('input propertychange', function () {
var maxLength = 4000;
if ($(this).val().length > maxLength) {
$(this).val($(this).val().substring(0, maxLength));
}
});
IE9、FF、Chromeで動作し、ユーザーにカウントダウンを提供するこのjQueryを試してください。
$("#comments").bind("keyup keydown", function() {
var max = 500;
var value = $(this).val();
var left = max - value.length;
if(left < 0) {
$(this).val( value.slice(0, left) );
left = 0;
}
$("#charcount").text(left);
});
<textarea id="comments" onkeyup="ismaxlength(this,500)"></textarea>
<span class="max-char-limit"><span id="charcount">500</span> characters left</span>
上記のコードの小さな問題は、val()がchange()イベントをトリガーしないため、backbone.js(またはモデルバインディング用の別のフレームワーク)を使用している場合、モデルが更新されないことです。
私は解決策が私のためにうまく働いたことを投稿しています。
$(function () {
$(document).on('keyup', '.ie8 textarea[maxlength], .ie9 textarea[maxlength]', function (e) {
var maxLength = $(this).attr('maxlength');
if (e.keyCode > 47 && $(this).val().length >= maxLength) {
$(this).val($(this).val().substring(0, maxLength)).trigger('change');
}
return true;
});
});