这是我尝试限制输入文本区域的字符数:
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个字符?
答案 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) );