aboutsummaryrefslogtreecommitdiff
path: root/files/zh-cn/web/api/htmltextareaelement/index.html
blob: 415ada3f89bbe8395b898435c9e5c532dbc112a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
---
title: HTMLTextAreaElement
slug: Web/API/HTMLTextAreaElement
tags:
  - API
  - 参考
  - 接口
translation_of: Web/API/HTMLTextAreaElement
---
<div>{{APIRef("HTML DOM")}}</div>

<p><strong><code>HTMLTextAreaElement</code></strong> 接口提供了特殊的属性和方法,用于控制 {{HTMLElement("textarea")}} 元素的布局和展示。</p>

<p>{{InheritanceDiagram(600,120)}}</p>

<h2 id="属性">属性</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <td><code>form </code>{{readonlyInline}}</td>
   <td><code><em>object</em>:</code> 返回一个父表单元素的引用。如果这个元素没有被包含在一个表单元素中,则这个值是页面中任意一个 {{HTMLElement("form")}} 元素的 {{htmlattrxref("id", "form")}} 属性或者 <code>null</code></td>
  </tr>
  <tr>
   <td><code>type</code> {{readonlyInline}}</td>
   <td><code><em>string</em>:</code> 返回字符串 <code>textarea</code></td>
  </tr>
  <tr>
   <td><code>value</code></td>
   <td><code><em>string</em>:</code> Returns / Sets the raw value contained in the control.</td>
  </tr>
  <tr>
   <td><code>textLength</code> {{readonlyInline}}</td>
   <td><code><em>long</em>:</code> Returns the codepoint length of the control's <code>value</code>. Same as <code>calling value.length</code></td>
  </tr>
  <tr>
   <td><code>defaultValue</code></td>
   <td><code><em>string</em>:</code> Returns / Sets the control's default value, which behaves like the {{domxref("Node.textContent")}} property.</td>
  </tr>
  <tr>
   <td><code>placeholder</code></td>
   <td><code><em>string</em>:</code> 返回/设置元素{{htmlattrxref("placeholder", "textarea")}} 属性, 用于提示用户在组件中应该输入什么。</td>
  </tr>
  <tr>
   <td><code>rows</code></td>
   <td><code><em>unsigned long</em>:</code> Returns / Sets the element's {{htmlattrxref("rows", "textarea")}} attribute, indicating the number of visible text lines for the control.</td>
  </tr>
  <tr>
   <td><code>cols</code></td>
   <td><code><em>unsigned long</em>:</code> Returns / Sets the element's {{htmlattrxref("cols", "textarea")}} attribute, indicating the visible width of the text area.</td>
  </tr>
  <tr>
   <td><code>autofocus</code></td>
   <td><code><em>boolean</em>:</code> Returns / Sets the element's {{htmlattrxref("autofocus", "textarea")}} attribute, indicating that the control should have input focus when the page loads</td>
  </tr>
  <tr>
   <td><code>name</code></td>
   <td><code><em>string</em>:</code> Returns / Sets the element's {{htmlattrxref("name", "textarea")}} attribute, containing the name of the control.</td>
  </tr>
  <tr>
   <td><code>disabled</code></td>
   <td><code><em>boolean</em>:</code> Returns / Sets the element's {{htmlattrxref("disabled", "textarea")}} attribute, indicating that the control is not available for interaction.</td>
  </tr>
  <tr>
   <td>{{domxref("HTMLTextAreaElement.labels")}}{{ReadOnlyInline}}</td>
   <td>{{domxref("NodeList")}}: Returns a list of label elements associated with this select element.</td>
  </tr>
  <tr>
   <td><code>maxLength</code></td>
   <td><code><em>long</em>:</code> Returns / Sets the element's {{htmlattrxref("maxlength", "textarea")}} attribute, indicating the maximum number of characters the user can enter. This constraint is evaluated only when the value changes.</td>
  </tr>
  <tr>
   <td><code>minLength</code></td>
   <td><code><em>long</em>:</code> Returns / Sets the element's {{htmlattrxref("minlength", "textarea")}} attribute, indicating the minimum number of characters the user can enter. This constraint is evaluated only when the value changes.</td>
  </tr>
  <tr>
   <td><code>accessKey</code></td>
   <td><code><em>string</em>:</code> Returns / Sets the element's {{htmlattrxref("accesskey", "textarea")}} attribute.</td>
  </tr>
  <tr>
   <td><code>readOnly</code></td>
   <td><code><em>boolean</em>:</code> Returns / Sets the element's {{htmlattrxref("readonly", "textarea")}} attribute, indicating that the user cannot modify the value of the control.</td>
  </tr>
  <tr>
   <td><code>required</code></td>
   <td><code><em>boolean</em>:</code> Returns / Sets the element's {{htmlattrxref("required", "textarea")}} attribute, indicating that the user must specify a value before submitting the form.</td>
  </tr>
  <tr>
   <td><code>tabIndex</code></td>
   <td><code><em>long</em>:</code> Returns / Sets the position of the element in the tabbing navigation order for the current document.</td>
  </tr>
  <tr>
   <td><code>selectionStart</code></td>
   <td><code><em>unsigned long</em>:</code> Returns / Sets the index of the beginning of selected text. If no text is selected, contains the index of the character that follows the input cursor. On being set, the control behaves as if <code>setSelectionRange()</code> had been called with this as the first argument, and <code>selectionEnd</code> as the second argument.</td>
  </tr>
  <tr>
   <td><code>selectionEnd</code></td>
   <td><code><em>unsigned long</em>:</code> Returns / Sets the index of the end of selected text. If no text is selected, contains the index of the character that follows the input cursor. On being set, the control behaves as if <code>setSelectionRange()</code> had been called with this as the second argument, and <code>selectionStart</code> as the first argument.</td>
  </tr>
  <tr>
   <td><code>selectionDirection</code></td>
   <td><code><em>string</em>:</code> Returns / Sets the direction in which selection occurred. This is <code>"forward"</code> if selection was performed in the start-to-end direction of the current locale, or <code>"backward"</code> for the opposite direction. This can also be <code>"none"</code> if the direction is unknown."</td>
  </tr>
  <tr>
   <td><code>validity</code> {{readonlyInline}}</td>
   <td><code><em>{{domxref("ValidityState")}} object</em>:</code> Returns the validity states that this element is in.</td>
  </tr>
  <tr>
   <td><code>willValidate</code> {{readonlyInline}}</td>
   <td>
    <p><code><em>boolean</em>:</code> Returns whether the element is a candidate for constraint validation. <code>false</code> if any conditions bar it from constraint validation, including its <code>readOnly</code> or <code>disabled</code> property is <code>true</code>.</p>
   </td>
  </tr>
  <tr>
   <td><code>validationMessage</code> {{readonlyInline}}</td>
   <td><code><em>string</em>:</code> Returns a localized message that describes the validation constraints that the control does not satisfy (if any). This is the empty string if the control is not a candidate for constraint validation (<code>willValidate</code> is <code>false</code>), or it satisfies its constraints.</td>
  </tr>
  <tr>
   <td><code>autocomplete</code> {{experimental_inline}}</td>
   <td></td>
  </tr>
  <tr>
   <td><code>autocapitalize</code> {{experimental_inline}}</td>
   <td><code><em>string</em>:</code> Returns / Sets the element's capitalization behavior for user input. Valid values are: <code>none</code>, <code>off</code>, <code>characters</code>, <code>words</code>, <code>sentences</code>.</td>
  </tr>
  <tr>
   <td><code>inputMode</code> {{experimental_inline}}</td>
   <td></td>
  </tr>
  <tr>
   <td><code>wrap</code> {{gecko_minversion_inline("2.0")}}</td>
   <td><code><em>string</em>:</code> Returns / Sets the {{htmlattrxref("wrap", "textarea")}} HTML attribute, indicating how the control wraps text.</td>
  </tr>
 </tbody>
</table>

<p>The two properties <code>tabIndex</code> and <code>accessKey</code> are inherited from {{domxref("HTMLElement")}} from HTML5 on, but were defined on <code>HTMLTextAreaElement</code> in DOM Level 2 HTML and earlier specifications.</p>

<h2 id="方法">方法</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <td>{{domxref("HTMLElement/blur", "blur()")}}</td>
   <td>Removes focus from the control; keystrokes will subsequently go nowhere.</td>
  </tr>
  <tr>
   <td>{{domxref("HTMLElement/focus", "focus()")}}</td>
   <td>Gives focus to the control; keystrokes will subsequently go to this element.</td>
  </tr>
  <tr>
   <td>{{domxref("HTMLInputElement/select", "select()")}}</td>
   <td>Selects the contents of the control.</td>
  </tr>
  <tr>
   <td>{{domxref("HTMLInputElement/setRangeText", "setRangeText()")}}</td>
   <td>Replaces a range of text in the element with new text.</td>
  </tr>
  <tr>
   <td>{{domxref("HTMLInputElement/setSelectionRange", "setSelectionRange()")}}</td>
   <td>Selects a range of text in the element (but does not focus it).</td>
  </tr>
  <tr>
   <td><code>checkValidity()</code></td>
   <td>Returns <code>false</code> if the button is a candidate for constraint validation, and it does not satisfy its constraints. In this case, it also fires a cancelable <code>invalid</code> event at the control. It returns <code>true</code> if the control is not a candidate for constraint validation, or if it satisfies its constraints.</td>
  </tr>
  <tr>
   <td><code>reportValidity()</code></td>
   <td>
    <p>This method reports the problems with the constraints on the element, if any, to the user. If there are problems, it fires a cancelable <code>invalid</code> event at the element, and returns <code>false</code>; if there are no problems, it returns <code>true</code>.</p>
   </td>
  </tr>
  <tr>
   <td><code>setCustomValidity(DOMstring)</code></td>
   <td>Sets a custom validity message for the element. If this message is not the empty string, then the element is suffering from a custom validity error, and does not validate.</td>
  </tr>
 </tbody>
</table>

<p>The two methods <code>blur()</code> and <code>focus()</code> are inherited from {{domxref("HTMLElement")}} from HTML5 on, but were defined on <code>HTMLTextAreaElement</code> in DOM Level 2 HTML and earlier specifications.</p>

<h2 id="事件">事件</h2>

<p>Listen to these events using <code><a href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener">addEventListener()</a></code> or by assigning an event listener to the <code>on<em>eventname</em></code> property of this interface:</p>

<dl>
 <dt><a href="/en-US/docs/Web/API/HTMLElement/input_event"><code>input</code> event</a></dt>
 <dd>Fires when the <code>value</code> of an {{HTMLElement("input")}}, {{HTMLElement("select")}}, or {{HTMLElement("textarea")}} element has been changed.</dd>
</dl>

<h2 id="示例">示例</h2>

<h3 id="Autogrowing_textarea_example">Autogrowing textarea example</h3>

<p>Make a textarea autogrow while typing:</p>

<p>JavaScript function:</p>

<pre class="brush: js">function autoGrow (oField) {
  if (oField.scrollHeight &gt; oField.clientHeight) {
    oField.style.height = oField.scrollHeight + "px";
  }
}</pre>

<p>CSS:</p>

<pre class="brush: css">textarea.noscrollbars {
  overflow: hidden;
  width: 300px;
  height: 100px;
}</pre>

<p>HTML:</p>

<pre class="brush: html">&lt;form&gt;
  &lt;fieldset&gt;
    &lt;legend&gt;Your comments&lt;/legend&gt;
    &lt;p&gt;&lt;textarea class="noscrollbars" onkeyup="autoGrow(this);"&gt;&lt;/textarea&gt;&lt;/p&gt;
    &lt;p&gt;&lt;input type="submit" value="Send" /&gt;&lt;/p&gt;
  &lt;/fieldset&gt;
&lt;/form&gt;
</pre>

<p>{{EmbedLiveSample('Autogrowing_textarea_example', 600, 300)}}</p>

<h3 id="Insert_HTML_tags_example">Insert HTML tags example</h3>

<p>Insert some HTML tags or <em>smiles</em> or any custom text in a textarea.<br>
 JavaScript function:</p>

<pre class="brush: js">function insertMetachars(sStartTag, sEndTag) {
  var bDouble = arguments.length &gt; 1, oMsgInput = document.myForm.myTxtArea, nSelStart = oMsgInput.selectionStart, nSelEnd = oMsgInput.selectionEnd, sOldText = oMsgInput.value;
  oMsgInput.value = sOldText.substring(0, nSelStart) + (bDouble ? sStartTag + sOldText.substring(nSelStart, nSelEnd) + sEndTag : sStartTag) + sOldText.substring(nSelEnd);
  oMsgInput.setSelectionRange(bDouble || nSelStart === nSelEnd ? nSelStart + sStartTag.length : nSelStart, (bDouble ? nSelEnd : nSelStart) + sStartTag.length);
  oMsgInput.focus();
}</pre>

<p>CSS to decorate the internal span to behave like a link:</p>

<pre class="brush: css">.intLink {
  cursor: pointer;
  text-decoration: underline;
  color: #0000ff;
}</pre>

<p>HTML:</p>

<pre class="brush: html">&lt;form name="myForm"&gt;
&lt;p&gt;[&amp;nbsp;&lt;span class="intLink" onclick="insertMetachars('&amp;lt;strong&amp;gt;','&amp;lt;\/strong&amp;gt;');"&gt;&lt;strong&gt;Bold&lt;/strong&gt;&lt;/span&gt; | &lt;span class="intLink" onclick="insertMetachars('&amp;lt;em&amp;gt;','&amp;lt;\/em&amp;gt;');"&gt;&lt;em&gt;Italic&lt;/em&gt;&lt;/span&gt; | &lt;span class="intLink" onclick="var newURL=prompt('Enter the full URL for the link');if(newURL){insertMetachars('&amp;lt;a href=\u0022'+newURL+'\u0022&amp;gt;','&amp;lt;\/a&amp;gt;');}else{document.myForm.myTxtArea.focus();}"&gt;URL&lt;/span&gt; | &lt;span class="intLink" onclick="insertMetachars('\n&amp;lt;code&amp;gt;\n','\n&amp;lt;\/code&amp;gt;\n');"&gt;code&lt;/span&gt; | &lt;span class="intLink" onclick="insertMetachars(' :-)');"&gt;smile&lt;/span&gt; | etc. etc.&amp;nbsp;]&lt;/p&gt;
&lt;p&gt;&lt;textarea name="myTxtArea" rows="10" cols="50"&gt;Lorem ipsum dolor sit amet, consectetur adipiscing elit. Ut facilisis, arcu vitae adipiscing placerat, nisl lectus accumsan nisi, vitae iaculis sem neque vel lectus. Praesent tristique commodo lorem quis fringilla. Sed ac tellus eros. Sed consectetur eleifend felis vitae luctus. Praesent sagittis, est eget bibendum tincidunt, ligula diam tincidunt augue, a fermentum odio velit eget mi. Phasellus mattis, elit id fringilla semper, orci magna cursus ligula, non venenatis lacus augue sit amet dui. Pellentesque lacinia odio id nisi pulvinar commodo tempus at odio. Ut consectetur eros porttitor nunc mollis ultrices. Aenean porttitor, purus sollicitudin viverra auctor, neque erat blandit sapien, sit amet tincidunt massa mi ac nibh. Proin nibh sem, bibendum ut placerat nec, cursus et lacus. Phasellus vel augue turpis. Nunc eu mauris eu leo blandit mollis interdum eget lorem. &lt;/textarea&gt;&lt;/p&gt;
&lt;/form&gt;
</pre>

<p>{{EmbedLiveSample('Insert_HTML_tags_example', 600, 300)}}</p>

<h3 id="Maximum_length_and_number_of_lines_example">Maximum length and number of lines example</h3>

<p>Create a textarea with a maximum number of characters per line and a maximum number of lines:</p>

<p>First, create a function that takes the text field and a key event as input and determines if any of the limits have been reached. If the limit has not been reached, it will return the key.</p>

<pre class="brush: js">function checkRows(oField, oKeyEvent) {
  var nKey = (oKeyEvent || /* old IE */ window.event || /* check is not supported! */ { keyCode: 38 }).keyCode,

    // put here the maximum number of characters per line:
    nCols = 30,
    // put here the maximum number of lines:
    nRows = 5,

    nSelS = oField.selectionStart, nSelE = oField.selectionEnd,
    sVal = oField.value, nLen = sVal.length,

    nBackward = nSelS &gt;= nCols ? nSelS - nCols : 0,
    nDeltaForw = sVal.substring(nBackward, nSelS).search(new RegExp("\\n(?!.{0," + String(nCols - 2) + "}\\n)")) + 1,
    nRowStart = nBackward + nDeltaForw,
    aReturns = (sVal.substring(0, nSelS) + sVal.substring(nSelE, sVal.length)).match(/\n/g),
    nRowEnd = nSelE + nRowStart + nCols - nSelS,
    sRow = sVal.substring(nRowStart, nSelS) + sVal.substring(nSelE, nRowEnd &gt; nLen ? nLen : nRowEnd),
    bKeepCols = nKey === 13 || nLen + 1 &lt; nCols || /\n/.test(sRow) || ((nRowStart === 0 || nDeltaForw &gt; 0 || nKey &gt; 0) &amp;&amp; (sRow.length &lt; nCols || (nKey &gt; 0 &amp;&amp; (nLen === nRowEnd || sVal.charAt(nRowEnd) === "\n"))));

  return (nKey !== 13 || (aReturns ? aReturns.length + 1 : 1) &lt; nRows) &amp;&amp; ((nKey &gt; 32 &amp;&amp; nKey &lt; 41) || bKeepCols);
}</pre>

<p>In the HTML we just need to hook our function to the `onkeypress` event and specify that our textarea does not accept pasting:</p>

<pre class="brush: html">&lt;form&gt;
  &lt;p&gt;Textarea with fixed number of characters per line:&lt;br /&gt;
    &lt;textarea cols="50" rows="10" onkeypress="return checkRows(this, event);"
              onpaste="return false;"&gt;&lt;/textarea&gt;
  &lt;/p&gt;
&lt;/form&gt;
</pre>

<p>{{EmbedLiveSample('Maximum_length_and_number_of_lines_example', 600, 300)}}</p>

<h2 id="规范">规范</h2>

<table class="standard-table">
 <tbody>
  <tr>
   <th scope="col">规范</th>
   <th scope="col">状态</th>
   <th scope="col">备注</th>
  </tr>
  <tr>
   <td>{{SpecName('HTML WHATWG', "#htmltextareaelement", "HTMLTextAreaElement")}}</td>
   <td>{{Spec2('HTML WHATWG')}}</td>
   <td></td>
  </tr>
  <tr>
   <td>{{SpecName('HTML5 W3C', "forms.html#the-textarea-element", "HTMLTextAreaElement")}}</td>
   <td>{{Spec2('HTML5 W3C')}}</td>
   <td>The attributes <code>tabindex</code> and <code>accesskey</code>, as well as the methods <code>blur()</code> and <code>focus()</code> are now defined on {{domxref("HTMLElement")}}.<br>
    The following attributes have been added: <code>autofocus</code>, <code>placeholder</code>, <code>dirName</code>, <code>wrap</code>, <code>maxLength</code>, <code>required</code>, <code>textLength</code>, <code>labels</code>, <code>selectionStart</code>, <code>selectionEnd</code>, <code>selectionDirection</code>, <code>validity</code>, <code>validationMessage</code>, and <code>willValidate</code>.<br>
    The following methods have been added: <code>checkValidity()</code>, <code>setCustomValidity()</code>, and <code>setSelectionRange()</code>.</td>
  </tr>
  <tr>
   <td>{{SpecName('DOM2 HTML', 'html.html#ID-ID-24874179', 'HTMLTextAreaElement')}}</td>
   <td>{{Spec2('DOM2 HTML')}}</td>
   <td>The property <code>defaultValue</code> doesn't contain the initial value of the <code>value</code> attribute, but the initial value of the content of the {{HTMLElement("textarea")}}.</td>
  </tr>
  <tr>
   <td>{{SpecName('DOM1', 'level-one-html.html#ID-24874179', 'HTMLTextAreaElement')}}</td>
   <td>{{Spec2('DOM1')}}</td>
   <td>Initial definition</td>
  </tr>
 </tbody>
</table>

<h2 id="浏览器兼容性">浏览器兼容性</h2>



<p>{{Compat("api.HTMLTextAreaElement")}}</p>