JavaScriptまたはjQueryを使用してテキストボックスのmaxlengthを変更したい:次を試してみましたが、役に立たなかったようです。
var a = document.getElementsByTagName('input');
for(var i=0; i<a.length; i++) {
if((a[i].type!= 'radio')||(a[i].type!= 'checkbox'))
a[i].maxlength = 5;
}
document.getElementsByTagName('input')[1].maxlength="3";
$().ready(function()
{
$("#inputID").maxlength(6);
});
何が間違っていますか?
最初の数行で何を達成しようとしているのかわかりませんが、これを試すことができます:
$(document).ready(function()
{
$("#ms_num").attr('maxlength','6');
});
最大長プロパティはキャメルケースです: maxLength
jQueryにはデフォルトでmaxlengthメソッドが付属していません。また、ドキュメントの準備機能が技術的に正しくありません。
$(document).ready(function () {
$("#ms_num")[0].maxLength = 6;
// OR:
$("#ms_num").attr('maxlength', 6);
// OR you can use prop if you are using jQuery 1.6+:
$("#ms_num").prop('maxLength', 6);
});
また、jQueryを使用しているため、次のようにコードを書き換えることができます(jQuery 1.6+を利用)。
$('input').each(function (index) {
var element = $(this);
if (index === 1) {
element.prop('maxLength', 3);
} else if (element.is(':radio') || element.is(':checkbox')) {
element.prop('maxLength', 5);
}
});
$(function() {
$("#ms_num").prop('maxLength', 6);
});
プロパティではなく属性を設定します
$("#ms_num").attr("maxlength", 6);
jQueryがなくても使用できます
document.getElementById('text_input').setAttribute('maxlength',200);
$('#yourTextBoxId').live('change keyup paste', function(){
if ($('#yourTextBoxId').val().length > 11) {
$('#yourTextBoxId').val($('#yourTextBoxId').val().substr(0,10));
}
});
私はこれをパフォーマンスとパフォーマンスのためにキャッシュする変数とセレクターと共に使用しました。
maxlength="10"
?例えば、
<input type="text" maxlength="10">
次のように作成できます。
$('#inputID').keypress(function () {
var maxLength = $(this).val().length;
if (maxLength >= 5) {
alert('You cannot enter more than ' + maxLength + ' chars');
return false;
}
});