5

根据互联网研究,最大长度属性不适用于 IE 8 和 9

为了解决这个问题,我从这里尝试了一个解决方案,它与另一个用于演示文本区域的功能一起使用:

//Dynamic append the textarea row
function do_resize(textArea) {
    while (
        textArea.rows > 1 &&
        textArea.scrollHeight < textArea.offsetHeight
    )
    {
        textArea.rows--;
    }
    while (textArea.scrollHeight > textArea.offsetHeight)
    {
        textArea.rows++;
    }
    textArea.rows++
}


<textarea name="q<%=countNo%>_ans" rows="3" cols="55" maxlength="2000" style="resize: none;" onkeyup="new do_resize(this);" onKeyPress="return ( this.value.length < 2000);"></textarea>

问题是,在 IE8 9 中超过 2000 的 textarea 无法输入任何字符,但我仍然可以使用超出 textarea 限制的复制和粘贴功能。如何解决这个问题?谢谢

4

4 回答 4

13

当达到限制时,问题中的代码有效地禁用了从键盘输入。要对粘贴的内容也施加限制,您还需要处理其他事件。以下代码将 textarea 内容截断为给定长度。这不是很好的可用性(您可能应该表示尝试超出限制,而不是静默截断,并且您可以在页面上设置一个字符计数器来帮助用户),但它可以满足要求:

<textarea maxlength=2000
  onchange="testLength(this)"
  onkeyup="testLength(this)"
  onpaste="testLength(this)"
></textarea>
<script>
var maxLength = 2000;
function testLength(ta) {
  if(ta.value.length > maxLength) {
    ta.value = ta.value.substring(0, maxLength);
  }
}
</script>
于 2013-06-04T06:41:21.007 回答
1

仅就这方面的一些故事而言,textarea 上的 maxlength 是一个新的 HTML5 功能,它仅在 10 中由 IE 首次支持。IE 9 及更低版本从未支持它。

于 2014-04-23T17:02:30.917 回答
1

使用此代码将适用于 IE 9 以下版本。仅在 if 条件下更改版本。

if(navigator.appVersion.indexOf("MSIE .9")!=-1)
                                {
                                    $('#inputid').bind('keyup blur', function () {
                                        var $this = $(this);
                                        var len = $this.val().length;
                                        var maxlength = 3;
                                        if (maxlength && len > maxlength) {
                                            var inputvalue= $this.val().slice(0, maxlength);
                                            $this.val("");
                                            $this.val(inputvalue);
                                        }
                                    });
                                }
于 2015-10-16T14:38:04.520 回答
-2

只需添加即可onpaste解决问题

<textarea name="q<%=countNo%>_ans" rows="3" cols="55" maxlength="2000" style="resize: none;" onkeyup="new do_resize(this);" onKeyPress="return ( this.value.length < 2000); onpaste="return ( this.value.length < 2000);"></textarea>
于 2013-06-04T03:02:39.433 回答