如何限制在文本区域中输入的字符数

时间:2010-05-10 19:12:53

标签: javascript jquery

这是我尝试限制输入文本区域的字符数:

var limit = 255;
var txt = $('textarea[id$=txtPurpose]');

$(txt).keyup(function() {
    var len = $(this).val().length;
    if (len > limit) {
        //this.value = this.value.substring(0, 50);
        $(this).addClass('goRed');
        $('#spn').text(len - limit + " characters exceeded");
        return false;
    } else {
        $(this).removeClass('goRed');
        $('#spn').text(limit - len + " characters left");
    }
});

但是,它不能很好地工作。如何在达到某个限制后阻止用户输入文本,比如255个字符?

6 个答案:

答案 0 :(得分:9)

这是我用来限制1200个字符的东西。当有人输入太多字符时,我只会截断该textarea的内容。

$(function() {
    //set up text length counter
    $('#id_limited_textarea').keyup(function() {
        update_chars_left(1200, $('#id_limited_textarea')[0], $('#text_chars_left'));
    });
    //and fire it on doc ready, too
    update_chars_left(1200, $('#id_limited_textarea')[0], $('#text_chars_left'));

});

function update_chars_left(max_len, target_input, display_element) {
   var text_len = target_input.value.length;
   if (text_len >= max_len) {
       target_input.value = target_input.value.substring(0, max_len); // truncate
       display_element.html("0");
   } else {
       display_element.html(max_len - text_len);
   }
}

答案 1 :(得分:9)

虽然这个问题已经很久了。如果我是你,我会做一些非常简单的事情,比如

<textarea maxlength="255"></textarea>

这会限制用户在textarea中只输入255个字符。

答案 2 :(得分:5)

$(this).val( $(this).val().substring(0, limit) );

答案 3 :(得分:3)

将此简化为裸骨基础:

<textarea name="message" onkeydown="return this.value.substr(0,160)"></textarea>

将你的最大值设置为160。

答案 4 :(得分:1)

我的插件:

(function($) {

   $.fn.textCounter = function(options) {

        var defaults = {
            maxlimit: 100,      // max limit character
            description: null,  // element for descript count character
            enter: true         // if accept enter
        };

        var options = $.extend({}, defaults, options);

        if (options.description != null) {
            if (typeof options.description == 'string')
                options.description = $('#' + options.description);
        }

        var fevent = function(ev) {

            var value = $(this).val(),
                k = ev.charCode || ev.keyCode || ev.which,
                incremente = 1;

            if (k == 8)
                incremente = -1;

            if (options.enter == false && k == 13)
                return false;

            if (ev.ctrlKey || ev.altKey || ev.metaKey)  //Ignore
                return true;

            if ((value.length + incremente) > options.maxlimit)
                return false;

            return true;
        };

        var fcounter = function(ev) {
            var value = $(this).val();
            $(options.description).text(options.maxlimit - value.length);
        };

        $(this).each(function(i, el) {
            if ($(this).is(':input')) {
                $(this).unbind('keypress.textCounter').bind('keypress.textCounter', fevent);
                $(this).unbind('keyup.textCounter').bind('keyup.textCounter', fcounter);
            }
        });

    };

})(jQuery);

答案 5 :(得分:0)

var limit="NO of characters";<br><br>
$(this).val( $(this).val().substring(0, limit) );