- : The Textarea element
- Try it
- Attributes
- Styling with CSS
- Baseline inconsistency
- Controlling whether a textarea is resizable
- Styling valid and invalid values
- Examples
- Basic example
- Example using «minlength» and «maxlength»
- Example using «placeholder»
- Disabled and readonly
- Technical summary
- HTML Tag
- Browser Support
- Attributes
- Global Attributes
- Event Attributes
- More Examples
- Example
: The Textarea element
The HTML element represents a multi-line plain-text editing control, useful when you want to allow users to enter a sizeable amount of free-form text, for example a comment on a review or feedback form.
Try it
The above example demonstrates a number of features of :
The element also accepts several attributes common to form s, such as autocomplete , autofocus , disabled , placeholder , readonly , and required .
Attributes
This element includes the global attributes.
This attribute indicates whether the value of the control can be automatically completed by the browser. Possible values are:
- off : The user must explicitly enter a value into this field for every use, or the document provides its own auto-completion method; the browser does not automatically complete the entry.
- on : The browser can automatically complete the value based on values that the user has entered during previous uses.
If the autocomplete attribute is not specified on a element, then the browser uses the autocomplete attribute value of the element’s form owner. The form owner is either the element that this element is a descendant of or the form element whose id is specified by the form attribute of the input element. For more information, see the autocomplete attribute in .
A string which indicates whether or not to activate automatic spelling correction and processing of text substitutions (if any are configured) while the user is editing this textarea . Permitted values are:
Enable automatic spelling correction and text substitutions.
Disable automatic spelling correction and text substitutions.
This Boolean attribute lets you specify that a form control should have input focus when the page loads. Only one form-associated element in a document can have this attribute specified.
The visible width of the text control, in average character widths. If it is specified, it must be a positive integer. If it is not specified, the default value is 20 .
This Boolean attribute indicates that the user cannot interact with the control. If this attribute is not specified, the control inherits its setting from the containing element, for example ; if there is no containing element when the disabled attribute is set, the control is enabled.
The form element that the element is associated with (its «form owner»). The value of the attribute must be the id of a form element in the same document. If this attribute is not specified, the element must be a descendant of a form element. This attribute enables you to place elements anywhere within a document, not just as descendants of form elements.
The maximum number of characters (UTF-16 code units) that the user can enter. If this value isn’t specified, the user can enter an unlimited number of characters.
The minimum number of characters (UTF-16 code units) required that the user should enter.
A hint to the user of what can be entered in the control. Carriage returns or line-feeds within the placeholder text must be treated as line breaks when rendering the hint.
Note: Placeholders should only be used to show an example of the type of data that should be entered into a form; they are not a substitute for a proper element tied to the input. See Labels and placeholders in : The Input (Form Input) element for a full explanation.
This Boolean attribute indicates that the user cannot modify the value of the control. Unlike the disabled attribute, the readonly attribute does not prevent the user from clicking or selecting in the control. The value of a read-only control is still submitted with the form.
This attribute specifies that the user must fill in a value before submitting a form.
The number of visible text lines for the control. If it is specified, it must be a positive integer. If it is not specified, the default value is 2.
Specifies whether the is subject to spell checking by the underlying browser/OS. The value can be:
- true : Indicates that the element needs to have its spelling and grammar checked.
- default : Indicates that the element is to act according to a default behavior, possibly based on the parent element’s own spellcheck value.
- false : Indicates that the element should not be spell checked.
Indicates how the control wraps text. Possible values are:
- hard : The browser automatically inserts line breaks (CR+LF) so that each line has no more than the width of the control; the cols attribute must also be specified for this to take effect.
- soft : The browser ensures that all line breaks in the value consist of a CR+LF pair, but does not insert any additional line breaks.
- off Non-Standard : Like soft but changes appearance to white-space: pre so line segments exceeding cols are not wrapped and the becomes horizontally scrollable.
If this attribute is not specified, soft is its default value.
Styling with CSS
is a replaced element — it has intrinsic dimensions, like a raster image. By default, its display value is inline-block . Compared to other form elements it is relatively easy to style, with its box model, fonts, color scheme, etc. being easily manipulable using regular CSS.
Styling HTML forms provides some useful tips on styling s.
Baseline inconsistency
The HTML specification doesn’t define where the baseline of a is, so different browsers set it to different positions. For Gecko, the baseline is set on the baseline of the first line of the textarea, on another browser it may be set on the bottom of the box. Don’t use vertical-align : baseline on it; the behavior is unpredictable.
Controlling whether a textarea is resizable
In most browsers, s are resizable — you’ll notice the drag handle in the right-hand corner, which can be used to alter the size of the element on the page. This is controlled by the resize CSS property — resizing is enabled by default, but you can explicitly disable it using a resize value of none :
Styling valid and invalid values
Valid and invalid values of a element (e.g. those within, and outside the bounds set by minlength , maxlength , or required ) can be highlighted using the :valid and :invalid pseudo-classes. For example, to give your textarea a different border depending on whether it is valid or invalid:
textarea:invalid border: 2px dashed red; > textarea:valid border: 2px solid lime; >
Examples
Basic example
The following example shows a very simple textarea, with a set numbers of rows and columns and some default content.
textarea name="textarea" rows="10" cols="50">Write something heretextarea>
Example using «minlength» and «maxlength»
This example has a minimum and maximum number of characters — of 10 and 20 respectively. Try it and see.
textarea name="textarea" rows="5" cols="30" minlength="10" maxlength="20">Write something heretextarea>
Note that minlength doesn’t stop the user from removing characters so that the number entered goes past the minimum, but it does make the value entered into the invalid. Also note that even if you have a minlength value set (3, for example), an empty is still considered valid unless you also have the required attribute set.
Example using «placeholder»
This example has a placeholder set. Notice how it disappears when you start typing into the box.
textarea name="textarea" rows="5" cols="30" placeholder="Comment text.">textarea>
Note: Placeholders should only be used to show an example of the type of data that should be entered into a form; they are not a substitute for a proper element tied to the input. See Labels and placeholders in : The Input (Form Input) element for a full explanation.
Disabled and readonly
This example shows two s — one of which is disabled , and one of which is readonly . Have a play with both and you’ll see the difference in behavior — the disabled element is not selectable in any way (and its value is not submitted), whereas the readonly element is selectable and its contents copyable (and its value is submitted); you just can’t edit the contents.
Note: In browsers other than Firefox, such as chrome, the disabled textarea content may be selectable and copyable.
textarea name="textarea" rows="5" cols="30" disabled>I am a disabled textareatextarea> textarea name="textarea" rows="5" cols="30" readonly>I am a readonly textareatextarea>
Technical summary
Content categories | Flow content, phrasing content, Interactive content, listed, labelable, resettable, and submittable form-associated element. |
---|---|
Permitted content | Text |
Tag omission | None, both the starting and ending tag are mandatory. |
Permitted parents | Any element that accepts phrasing content. |
Implicit ARIA role | textbox |
Permitted ARIA roles | No role permitted |
DOM interface | HTMLTextAreaElement |
HTML Tag
The tag defines a multi-line text input control.
The element is often used in a form, to collect user inputs like comments or reviews.
A text area can hold an unlimited number of characters, and the text renders in a fixed-width font (usually Courier).
The size of a text area is specified by the cols and rows attributes (or with CSS).
The name attribute is needed to reference the form data after the form is submitted (if you omit the name attribute, no data from the text area will be submitted).
The id attribute is needed to associate the text area with a label.
Browser Support
Attributes
Attribute | Value | Description |
---|---|---|
autofocus | autofocus | Specifies that a text area should automatically get focus when the page loads |
cols | number | Specifies the visible width of a text area |
dirname | textareaname.dir | Specifies that the text direction of the textarea will be submitted |
disabled | disabled | Specifies that a text area should be disabled |
form | form_id | Specifies which form the text area belongs to |
maxlength | number | Specifies the maximum number of characters allowed in the text area |
name | text | Specifies a name for a text area |
placeholder | text | Specifies a short hint that describes the expected value of a text area |
readonly | readonly | Specifies that a text area should be read-only |
required | required | Specifies that a text area is required/must be filled out |
rows | number | Specifies the visible number of lines in a text area |
wrap | hard soft | Specifies how the text in a text area is to be wrapped when submitted in a form |
Global Attributes
Event Attributes
More Examples
Example
Disable default resize option: