我正在尝试使用JavaScript动态设置输入字段的maxlength。显然这是IE中的一个问题,我找到了部分解决方案。
$("input#title").get(0).setAttribute("max_length", 25);
$("input#title").get(0).setAttribute(
"onkeypress",
"return limitMe(event, this)");
function limitMe(evt, txt) {
if (evt.which && evt.which == 8) return true;
else return (txt.value.length < txt.getAttribute("max_length");
}
它适用于Firefox,但出于某种原因不适用于IE。但是,它适用于如下设置的输入字段:
<input type="text" max_length="25" onkeypress="return limitMe(event, this);"/>
但是由于输入字段是动态创建的,我不能这样做......有什么想法吗?
答案 0 :(得分:9)
如果你正在使用jQuery那么为什么不充分利用它的抽象呢?
E.g。
而不是:
$("input#title").get(0).setAttribute("max_length", 25);
$("input#title").get(0).setAttribute(
"onkeypress",
"return limitMe(event, this)");
function limitMe(evt, txt) {
if (evt.which && evt.which == 8) return true;
else return (txt.value.length < txt.getAttribute("max_length");
}
这样做:
$('input#title').attr('maxLength','25').keypress(limitMe);
function limitMe(e) {
if (e.keyCode == 8) { return true; }
return this.value.length < $(this).attr("maxLength");
}
编辑:它在IE中不起作用的原因可能是因为您通过setAttribute附加了'onKeyPress'处理程序。 - 这不是注册事件处理程序的正确方法。
答案 1 :(得分:5)
您要查找的属性是maxlength
,而不是max_length
。请参阅here。
答案 2 :(得分:2)
不要忘记,如果您通过JavaScript设置maxlength,其他人可以轻松地将maxlength更改为他们喜欢的任何内容。您仍然需要验证服务器上提交的数据。
答案 3 :(得分:2)
IE在setAttribute()上区分大小写,只有“maxLength”有效...
var el=document.createElement('input'); el.setAttribute('maxLength',25);
答案 4 :(得分:1)
此处的所有答案都依赖于按键/粘贴事件。以下是使用input
事件的解决方案:
$('input').on('input', onInput);
var inputValue = '';
function onInput(e) {
if(e.currentTarget.value.length > 30) {
e.currentTarget.value = titleValue;
return;
}
inputValue = e.currentTarget.value;
}
答案 5 :(得分:0)
因为我在@James的答案上遇到了一些问题,所以我写的是即使在复制粘贴内容时也是如此,特别是在使用IE8时。我的实现使用jQuery及其实时事件。
jQuery(function () {
$('body').on('keydown.maxlength_fix', 'textarea[maxlength]', function (e) {
var $this = $(this);
window.setTimeout(function () {
var val = $this.val();
var maxlength = $this.attr('maxlength');
if (val.length > maxlength) {
$this.val(val.substr(0, maxlength));
}
}, 4);
});
});
答案 6 :(得分:0)
我的代码也打印出写入/最大字符,忽略该部分。
$("[maxlength]").bind("keyup focusin", function(){
var maxkey = $(this).attr("maxlength");
var length = $(this).val().length;
var value = $(this).val();
$(this).parent().find(".counter").text(length+"/"+maxkey);
if (length > maxkey) $(this).val(value.substring(0, maxkey));
}).bind("focusout", function(){$(this).parent().find(".counter").text("")});