textarea character limit
Solution 1
I found a good solution that uses the maxlength attribute if the browser supports it, and falls back to an unobtrusive javascript pollyfill in unsupporting browsers.
Thanks to @Dan Tello's comment I fixed it up so it works in IE7+ as well:
HTML:
<textarea maxlength="50" id="text">This textarea has a character limit of 50.</textarea>
Javascript:
function maxLength(el) {
if (!('maxLength' in el)) {
var max = el.attributes.maxLength.value;
el.onkeypress = function () {
if (this.value.length >= max) return false;
};
}
}
maxLength(document.getElementById("text"));
There is no such thing as a minlength
attribute in HTML5.
For the following input types: number
, range
, date
, datetime
, datetime-local
, month
, time
, and week
(which aren't fully supported yet) use the min
and max
attributes.
Solution 2
This is entirely untested but it should do what you need.
Update : here's a jsfiddle to look at. Seems to be working. link
You would past it into a js file and reference it after your jquery reference. You would then call it like this..
$("textarea").characterCounter(200);
A brief explanation of what is going on..
On every keyup event the function is checking what type of key is pressed. If it is acceptable the the counter will check the count, trim any excess and prevent any further input once the limit is reached.
The plugin should handle pasting into the target too.
; (function ($) {
$.fn.characterCounter = function (limit) {
return this.filter("textarea, input:text").each(function () {
var $this = $(this),
checkCharacters = function (event) {
if ($this.val().length > limit) {
// Trim the string as paste would allow you to make it
// more than the limit.
$this.val($this.val().substring(0, limit))
// Cancel the original event
event.preventDefault();
event.stopPropagation();
}
};
$this.keyup(function (event) {
// Keys "enumeration"
var keys = {
BACKSPACE: 8,
TAB: 9,
LEFT: 37,
UP: 38,
RIGHT: 39,
DOWN: 40
};
// which normalizes keycode and charcode.
switch (event.which) {
case keys.UP:
case keys.DOWN:
case keys.LEFT:
case keys.RIGHT:
case keys.TAB:
break;
default:
checkCharacters(event);
break;
}
});
// Handle cut/paste.
$this.bind("paste cut", function (event) {
// Delay so that paste value is captured.
setTimeout(function () { checkCharacters(event); event = null; }, 150);
});
});
};
} (jQuery));
Solution 3
using maxlength attribute of textarea would do the trick ... simple html code .. not JS or JQuery or Server Side Check Required....
Solution 4
I think that doing this might be easier than most people think!
Try this:
var yourTextArea = document.getElementById("usertext").value;
// In case you want to limit the number of characters in no less than, say, 10
// or no more than 400.
if (yourTextArea.length < 10 || yourTextArea.length > 400) {
alert("The field must have no less than 10 and no more than 400 characters.");
return false;
}
Please let me know it this was useful. And if so, vote up! Thx!
Daniel
Solution 5
This works on keyup and paste, it colors the text red when you are almost up to the limit, truncates it when you go over and alerts you to edit your text, which you can do.
var t2= /* textarea reference*/
t2.onkeyup= t2.onpaste= function(e){
e= e || window.event;
var who= e.target || e.srcElement;
if(who){
var val= who.value, L= val.length;
if(L> 175){
who.style.color= 'red';
}
else who.style.color= ''
if(L> 180){
who.value= who.value.substring(0, 175);
alert('Your message is too long, please shorten it to 180 characters or less');
who.style.color= '';
}
}
}
Web_Designer
Warning: Stack overflow was a deep pit for me. I wanted to be esteemed by others. But what is highly esteemed by others is detestable in the sight of God. Jesus said, "What would it profit you to gain the whole world and forfeit your soul?" God is patient, but He never fails to fulfill His word. Judgement will come where everyone will be repaid for their deeds. Read the Bible and give up everything to obey Jesus.
Updated on March 14, 2020Comments
-
Web_Designer about 4 years
I would like to be able to limit the number of characters in a textarea. The method I am using works great in Google Chrome, but is slow in Firefox, and doesn't work in IE.
Javascript:
function len(){ t_v=textarea.value; if(t_v.length>180){ long_post_container.innerHTML=long_post; post_button.className=post_button.className.replace('post_it_regular','post_it_disabled'); post_button.disabled=true; } else{ long_post_container.innerHTML=""; post_button.className=post_button.className.replace('post_it_disabled','post_it_regular'); post_button.disabled=false; } if(t_v.length>186){ t_v=t_v.substring(0,186); } }
HTML:
<textarea id="user_post_textarea" name="user_post_textarea" cols="28" rows="1" onkeypress="len();" onkeyup="len();"></textarea>
Javascript at bottom of body element:
textarea=document.getElementById('user_post_textarea');
-
Dejan Marjanović about 13 yearsIt will match exactly 500, what if user pastes text and then continue typing?
-
Dejan Marjanović about 13 yearsYes, but just to be safe. Anyway he needs to check it on submit and on server side.
-
Web_Designer about 13 yearsWhat does returning false do in this instance? Does it not allow additional text to be typed in the textarea?
-
Christian about 13 yearsThat makes it very slow. Consider that you are move contents on each keypress, even cursor movement.
-
Christian about 13 yearsExactly. Returning false aborts the event. In jQuery there's something like "stopPropagation" or something.
-
Web_Designer about 13 yearsOk, So I implimented your example but when I reached the character limit (500) it just stopped and I couldn't even back space or delete part of the text.
-
Christian about 13 yearsRight, you would want to filter out [DEL] and [BACKSPACE]
-
Web_Designer about 13 yearsIn your example then when a key is held down the textarea doesn't trim the number of characters until the key is released. I would like something like @webarto has, but that will filter out [DEL] and [BACKSPACE].
-
Web_Designer about 13 yearsThere I filtered the necessary navigation keys and edited @Christian Sciberras answer to provide the new code that I have tested In Chrome and IE with excellent results, and Firefox with somewhat choppy results. Anyways at least it works! Thank you everyone for your help :)
-
Web_Designer about 13 yearsThe example you have allows the placement of another character before it removes this character half a second later but this isn't really what I wanted. I edited the answer @Christian Sciberras provided to filter necessary keycodes and it works great!
-
James South about 13 years@inquisitive: That could have been fixed easily by changing the line that says if ($this.val().length > limit) to ($this.val().length >= limit). I hope to god you are not writing it in-line like in Christian's example and have at least moved it into a separate js file.
-
Dan Tello about 12 yearsYou edited method seems to be busted in IE 7 + 8. First one seems to work though.
-
MikeMurko over 11 yearsall you need to do is .keyup(function(e) { if (>500) { e.preventDefault() });
-
Web_Designer over 11 years@DanTello New code with a new demo. Works in IE7+ and other browsers. haven't checked in IE6-.
-
Nilesh patel about 11 yearsNot working in ie "Invalid operand to 'in': Object expected "
-
Web_Designer about 11 years@Nileshpatel I've tested my demo (Here's a fullscreen version for IE testing) in IE7+ with no errors in the console, and the character limit working properly.
-
DanMan almost 11 yearsProblem is: if you run into the limit, it doesn't accept any key press anymore, so you can't even backspace the last sentence. You must use the context menu to delete something.
-
Web_Designer almost 11 yearsI can backspace just fine after hitting the limit in Chrome. What browser are you using? The code uses the
keypress
event not thekeydown
event. Returning false for akeypress
event shouldn't block control characters like backspace, shift, ctrl, etc. -
jplandrain over 9 yearsOlder browsers don't support maxlength. For IE, it must be version 10.
-
Darksymphony about 5 yearsYou can't press backspace or delete as DanMan mentioned in Firefox if the content is already over limit. In Chrome it works well, but not in FF
-
Darksymphony about 5 yearsyou must first check: if (event.charCode >= 48 && event.charCode <= 57 || event.key === "Backspace") {return true;} and then the rest. It will work in FF too
-
DvS about 3 yearsThis won’t prevent pasting a bunch of text, which limits its usefulness.