الفرق بين المراجعتين لصفحة: «HTML/textarea»
ط استبدال النص - ':(Content sectioning|Edits|Embedded content|Forms|Inline text semantics|Input Types|Interactive elements|Main Root|Metadata|Multimedia|Scripting|Table|Text Content)' ب':HTML $1' |
←التنسيق الافتراضي: إضافة التفاصيل |
||
(1 مراجعات متوسطة بواسطة نفس المستخدم غير معروضة) | |||
سطر 3: | سطر 3: | ||
مثال عن العنصر <code><textarea></code> بسيط:<syntaxhighlight lang="html"> | مثال عن العنصر <code><textarea></code> بسيط:<syntaxhighlight lang="html"> | ||
<textarea name="textarea"> | <textarea name="textarea">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== بطاقة العنصر == | |||
{| class="wikitable" style="width: 100%;" | {| class="wikitable" style="width: 100%;" | ||
|- | |- | ||
سطر 57: | سطر 59: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن استخدام الخاصية <code>autofocus</code>:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>autofocus</code>:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" | <textarea name="textarea" autofocus>اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 65: | سطر 66: | ||
تحديد العرض الظاهر لهذا العنصر مقدرًا بعرض المحارف، وإذا حُدِّدتَ هذه الخاصية فيجب أن تكون عددًا صحيحًا موجبًا، وإن لم تُحدَّد فقيمتها الافتراضية هي <code>20</code> (في HTML5). | تحديد العرض الظاهر لهذا العنصر مقدرًا بعرض المحارف، وإذا حُدِّدتَ هذه الخاصية فيجب أن تكون عددًا صحيحًا موجبًا، وإن لم تُحدَّد فقيمتها الافتراضية هي <code>20</code> (في HTML5). | ||
مثال عن استخدام الخاصيتين <code>cols</code> و <code>[[#rows|rows]]</code> لتحديد أبعاد مربع النص:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصيتين <code>cols</code> و <code>[[#rows|rows]]</code> لتحديد أبعاد مربع النص:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" | <textarea name="textarea" rows="10" cols="50">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 74: | سطر 73: | ||
تُشير هذه الخاصية المنطقية (Boolean) إلى أنَّ المستخدم لا يستطيع التفاعل مع هذا العنصر، وإذا لم تُحدَّد قيمة لهذه الخاصية فسترث قيمتها من العنصر الحاوي لها مثل العنصر <code>[[HTML/fieldset|<fieldset>]]</code>، وإذا لم يكن هنالك عنصرٌ حاوٍ لهذا العنصر له الخاصية <code>disabled</code>، فسيكون هذا العنصر مفعّلًا. | تُشير هذه الخاصية المنطقية (Boolean) إلى أنَّ المستخدم لا يستطيع التفاعل مع هذا العنصر، وإذا لم تُحدَّد قيمة لهذه الخاصية فسترث قيمتها من العنصر الحاوي لها مثل العنصر <code>[[HTML/fieldset|<fieldset>]]</code>، وإذا لم يكن هنالك عنصرٌ حاوٍ لهذا العنصر له الخاصية <code>disabled</code>، فسيكون هذا العنصر مفعّلًا. | ||
مثال عن استخدام الخاصية <code>disabled</code>:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>disabled</code>:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" disabled> | <textarea name="textarea" disabled>لا يمكنك الكتابة هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 86: | سطر 84: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن استخدام الخاصية <code>form</code> لربط مربع النص مع نموذج ليس أبًا له:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>form</code> لربط مربع النص مع نموذج ليس أبًا له:<syntaxhighlight lang="html"> | ||
<form action="action_page.php" id="from1"> | <form action="action_page.php" id="from1"> | ||
الاسم: <input type="text" name="username"> | |||
<input type="submit"> | <input type="submit"> | ||
</form> | </form> | ||
<textarea name="textarea" form="from1"> | <textarea name="textarea" form="from1">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 100: | سطر 97: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن استخدام الخاصية <code>maxlength</code> لتحديد عدد المحارف الأقصى الذي يستطيع المستخدم إدخاله:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>maxlength</code> لتحديد عدد المحارف الأقصى الذي يستطيع المستخدم إدخاله:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" maxlength="50"> | <textarea name="textarea" maxlength="50">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 110: | سطر 106: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن استخدام الخاصية <code>minlength</code> لتحديد أقل عدد محارف يجب أن يدخلها المستخدم، ولن يقبل المتصفح إرسال النموذج إذا كان عدد المحارف أقل من هذه القيمة؛ لاحظ كيف استعملنا الخاصية <code>[[#form|form]]</code> للإشارة إلى نموذج ليس أبًا للعنصر <code><textarea></code>:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>minlength</code> لتحديد أقل عدد محارف يجب أن يدخلها المستخدم، ولن يقبل المتصفح إرسال النموذج إذا كان عدد المحارف أقل من هذه القيمة؛ لاحظ كيف استعملنا الخاصية <code>[[#form|form]]</code> للإشارة إلى نموذج ليس أبًا للعنصر <code><textarea></code>:<syntaxhighlight lang="html"> | ||
<form action="action_page.php" id="from1"> | <form action="action_page.php" id="from1"> | ||
الاسم: <input type="text" name="username"> | |||
<input type="submit"> | <input type="submit"> | ||
</form> | </form> | ||
<textarea name="textarea" form="from1" minlength="10"> | <textarea name="textarea" form="from1" minlength="10">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 128: | سطر 122: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن العنصر <code><textarea></code> مع الخاصية <code>placeholder</code>:<syntaxhighlight lang="html"> | مثال عن العنصر <code><textarea></code> مع الخاصية <code>placeholder</code>:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" placeholder=" | <textarea name="textarea" placeholder="تلميحة عن المحتوى" | ||
rows="10" cols="50"></textarea> | |||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 137: | سطر 130: | ||
هذه الخاصية المنطقية تُشير أنَّ المستخدم لا يستطيع تعديل قيمة هذا العنصر، لكن على النقيض من الخاصية <code>disabled</code> فلن تمنع الخاصية <code>readonly</code> المستخدم من تحديد النص أو النقر على العنصر، وستُرسَل قيمة العنصر مع بيانات النموذج إلى الخادوم. | هذه الخاصية المنطقية تُشير أنَّ المستخدم لا يستطيع تعديل قيمة هذا العنصر، لكن على النقيض من الخاصية <code>disabled</code> فلن تمنع الخاصية <code>readonly</code> المستخدم من تحديد النص أو النقر على العنصر، وستُرسَل قيمة العنصر مع بيانات النموذج إلى الخادوم. | ||
مثال عن استخدام الخاصية <code>readonly</code>:<syntaxhighlight lang="html"> | مثال عن استخدام الخاصية <code>readonly</code>:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" readonly> | <textarea name="textarea" readonly>يمكن تحديد النص فقط</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
سطر 164: | سطر 155: | ||
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق. | ||
مثال عن إسناد القيمة <code>hard</code> إلى الخاصية <code>wrap</code>:<syntaxhighlight lang="html"> | مثال عن إسناد القيمة <code>hard</code> إلى الخاصية <code>wrap</code>:<syntaxhighlight lang="html"> | ||
<textarea name="textarea" cols="10" wrap="hard"> | <textarea name="textarea" cols="10" wrap="hard">اكتب نصًا هنا</textarea> | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== ملاحظات == | == ملاحظات == | ||
=== إعادة تحجيم العنصر <code><textarea></code> === | === إعادة تحجيم العنصر <code><textarea></code> === | ||
يمكن التحكم بتحجيم العنصر <textarea> باستخدام الخاصية <code>resize</code>، إذا إنَّ إعادة التحجيم مفعلة افتراضيًا، ويمكنك تعطيلها باستخدام قاعدة CSS الآتية:<syntaxhighlight lang="css"> | يمكن التحكم بتحجيم العنصر <code><textarea></code> باستخدام الخاصية <code>[[CSS/resize|resize]]</code>، إذا إنَّ إعادة التحجيم مفعلة افتراضيًا، ويمكنك تعطيلها باستخدام قاعدة [[CSS]] الآتية:<syntaxhighlight lang="css"> | ||
textarea { | textarea { | ||
resize: none; | resize: none; | ||
سطر 178: | سطر 167: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
=== التفاعل مع CSS === | === التفاعل مع [[CSS]] === | ||
أما بالنسبة إلى CSS، فالعنصر <code><textarea></code> هو عنصر مُستبدَل (replaced element)، ولا تُعرِّف مواصفة HTML أين يكون خط الأساس (baseline) للعنصر <code><textarea></code>، لذا سيستعمل كل متصفح مكانًا مختلفًا؛ وبالتالي لا يُنصَح باستخدام القيمة <code>baseline</code> للخاصية <code>vertical-align</code> في CSS، لأن سلوكها غير متوقع. | أما بالنسبة إلى CSS، فالعنصر <code><textarea></code> هو عنصر مُستبدَل (replaced element)، ولا تُعرِّف مواصفة HTML أين يكون خط الأساس (baseline) للعنصر <code><textarea></code>، لذا سيستعمل كل متصفح مكانًا مختلفًا؛ وبالتالي لا يُنصَح باستخدام القيمة <code>baseline</code> للخاصية <code>[[CSS/vertical-align|vertical-align]]</code> في CSS، لأن سلوكها غير متوقع. | ||
يجدر بالذكر أنَّ العنصر <code><textarea></code> له أبعاد صافية، مثل الصور النقطية (<code>[[HTML/img|<img>]]</code>). | يجدر بالذكر أنَّ العنصر <code><textarea></code> له أبعاد صافية، مثل الصور النقطية (<code>[[HTML/img|<img>]]</code>). | ||
== التنسيق الافتراضي == | |||
تختلف المتصفحات في طريقة عرضها للعنصر <code><textarea></code>، لكنها تشترك بضبط الخاصية <code>[[CSS/display|display]]</code> إلى <code>inline-block</code>، وتغيير المؤشر <code>[[CSS/cursor|cursor]]</code> إلى <code>text</code>، وتغيير عائلة النص <code>[[CSS/font-family|font-family]]</code> إلى <code>monospace</code>. أما بقية الخاصيات (مثل الإطار <code>[[CSS/border|border]]</code>، والخلفية <code>[[CSS/background|background]]</code>، والحواشي <code>[[CSS/padding|padding]]</code>، وغيرها...) فهي تختلف بين المتصفحات. | |||
==مصادر ومواصفات== | ==مصادر ومواصفات== |
المراجعة الحالية بتاريخ 05:10، 25 فبراير 2018
يُمثِّل العنصر <textarea>
عنصرًا من عناصر النماذج يوفِّر مربعًا نصيًا متعدد الأسطر قابلًا للتعديل.
مثال عن العنصر <textarea>
بسيط:
<textarea name="textarea">اكتب نصًا هنا</textarea>
بطاقة العنصر
تصنيفات المحتوى | عنصر تنظيمي، وعنصر عادي، وعنصر تفاعلي، وعنصر مرتبط بالنماذج. |
---|---|
المحتوى المسموح | النص. |
الوسم المختصر | لا يمكن حذف أيّ من وسمَي البداية أو النهاية. |
العناصر الأب | أي عنصر يقبل المحتوى العادي. |
واجهة DOM | HTMLTextAreaElement
|
دعم المتصفحات
Chrome | Firefox | Edge | Safari | Opera |
---|---|---|---|---|
مدعوم | مدعوم | مدعوم | مدعوم | مدعوم |
خاصية autocomplete
ما تزال غير مدعومة في أغلبية المتصفحات.
الخاصيات
يمكن استخدام الخاصيات العامة في هذا العنصر.
autocomplete
تُشير هذه الخاصية إن كانت قيمة هذا العنصر يمكن إكمالها تلقائيًا عبر المتصفح. القيم الممكنة لهذه الخاصية هي:
off
: يجب أن يُدخِل المستخدم القيم يدويًا في هذا الحقل في كل مرة، أو كانت الصفحة تُوفِّر طريقة للإكمال التلقائي للمدخلات بمعزل عن المتصفح، أي أنَّ المتصفح لا يتدخل بموضوع الإكمال التلقائي.on
: يمكن للمتصفح إكمال القيم المُدخَلة من المستخدم تلقائيًا اعتمادًا على القيم التي أدخلها المستخدم في المرات السابقة.
إذا لم تُحدَّد قيمة للخاصية autocomplete
على عنصر <textarea>
فسيستخدم المتصفح الخاصية autocomplete
للنموذج الذي ينتمي إليه هذا العنصر، وهو إما أن يكون العنصر <form>
الأب لهذا العنصر أو العنصر <form>
الذي استخدمنا قيمة الخاصية id
التابعة لها في خاصية form
في هذا العنصر.
لمزيدٍ من المعلومات، راجع فقرة الخاصية autocomplete
في صفحة العنصر <form>
.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
autofocus
تسمح لنا هذه الخاصية المنطقية (Boolean) بتحدد أنَّنا نريد أن ينتقل التركيز (focus) إلى هذا العنصر عند تحميل الصفحة ما لم يغيّره المستخدم (مثل الكتابة في عنصر إدخال مختلف).
لا يمكن أن تُستعمَل هذه الخاصية إلا في عنصر واحد فقط مرتبط بالنماذج في المستند.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن استخدام الخاصية autofocus
:
<textarea name="textarea" autofocus>اكتب نصًا هنا</textarea>
cols
تحديد العرض الظاهر لهذا العنصر مقدرًا بعرض المحارف، وإذا حُدِّدتَ هذه الخاصية فيجب أن تكون عددًا صحيحًا موجبًا، وإن لم تُحدَّد فقيمتها الافتراضية هي 20
(في HTML5).
مثال عن استخدام الخاصيتين cols
و rows
لتحديد أبعاد مربع النص:
<textarea name="textarea" rows="10" cols="50">اكتب نصًا هنا</textarea>
disabled
تُشير هذه الخاصية المنطقية (Boolean) إلى أنَّ المستخدم لا يستطيع التفاعل مع هذا العنصر، وإذا لم تُحدَّد قيمة لهذه الخاصية فسترث قيمتها من العنصر الحاوي لها مثل العنصر <fieldset>
، وإذا لم يكن هنالك عنصرٌ حاوٍ لهذا العنصر له الخاصية disabled
، فسيكون هذا العنصر مفعّلًا.
مثال عن استخدام الخاصية disabled
:
<textarea name="textarea" disabled>لا يمكنك الكتابة هنا</textarea>
form
تُحدِّد هذه الخاصية ما هو النموذج الذي ينتمي العنصر <textarea>
إليه، ويجب أن تكون قيمة هذه الخاصية هي مُعرِّف id
لعنصر <form>
في المستند نفسه.
تسمح لك هذه الخاصية بربط عناصر <textarea>
إلى عناصر <form>
الموجودة في أي مكان في المستند، لكن لا يجوز أن يرتبط عنصر <textarea>
موجود ضمن عنصر <form>
إلى عنصر <form>
آخر.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن استخدام الخاصية form
لربط مربع النص مع نموذج ليس أبًا له:
<form action="action_page.php" id="from1">
الاسم: <input type="text" name="username">
<input type="submit">
</form>
<textarea name="textarea" form="from1">اكتب نصًا هنا</textarea>
maxlength
العدد الأقصى للمحارف التي يستطيع المستخدم إدخالها، وإن لم تُحدَّد قيمة لهذه الخاصية فسيتمكن المستخدم من إدخال عدد غير محدود من المحارف.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن استخدام الخاصية maxlength
لتحديد عدد المحارف الأقصى الذي يستطيع المستخدم إدخاله:
<textarea name="textarea" maxlength="50">اكتب نصًا هنا</textarea>
minlength
العدد الأدنى للمحارف التي يجب على المستخدم إدخالها.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن استخدام الخاصية minlength
لتحديد أقل عدد محارف يجب أن يدخلها المستخدم، ولن يقبل المتصفح إرسال النموذج إذا كان عدد المحارف أقل من هذه القيمة؛ لاحظ كيف استعملنا الخاصية form
للإشارة إلى نموذج ليس أبًا للعنصر <textarea>
:
<form action="action_page.php" id="from1">
الاسم: <input type="text" name="username">
<input type="submit">
</form>
<textarea name="textarea" form="from1" minlength="10">اكتب نصًا هنا</textarea>
name
تُستخدَم هذه الخاصية لتحديد اسم هذا العنصر (الذي سيرتبط معه عند إرسال النموذج).
placeholder
تلميحة للمستخدم لكي يعرف ما الذي عليه أن يكتبه ضمن هذا العنصر، لاحظ أنَّ الأسطر الجديدة في نص التلميحة ستُعرَض في العنصر كما هي.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن العنصر <textarea>
مع الخاصية placeholder
:
<textarea name="textarea" placeholder="تلميحة عن المحتوى"
rows="10" cols="50"></textarea>
readonly
هذه الخاصية المنطقية تُشير أنَّ المستخدم لا يستطيع تعديل قيمة هذا العنصر، لكن على النقيض من الخاصية disabled
فلن تمنع الخاصية readonly
المستخدم من تحديد النص أو النقر على العنصر، وستُرسَل قيمة العنصر مع بيانات النموذج إلى الخادوم.
مثال عن استخدام الخاصية readonly
:
<textarea name="textarea" readonly>يمكن تحديد النص فقط</textarea>
required
خاصية منطقية (Boolean) تُشير إلى أنَّ هذه العنصر إجباري ويجب تحديد خيار من خياراته على الأقل.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
rows
تُمثِّل هذه الخاصية عدد الأسطر الظاهرة في العنصر.
spellcheck
ضبط هذه القيمة إلى true
يشير إلى أنَّ المتصفح يجب أن يتحقق من الأخطاء الإملائية والقاعدية. القيمة default
تُشير إلى أنَّ العنصر سيرث قيمة الخاصية spellcheck
للعنصر الأب أو يأخذها من المتصفح. أما القيمة false
فتعني أنَّه لا يجب التحقق من الأخطاء الإملائية والقاعدية في هذا العنصر.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
wrap
تُشير هذه الخاصية إلى كيفية التفاف النص في هذا العنصر، والقيم المسموحة هي:
hard
: سيضع المتصفح أسطرًا جديدةً (CR+LF) لكل سطر أطول من عرض هذا العنصر، ويجب حينئذٍ استخدام الخاصيةcols
.soft
: سيحرص المتصفح على أن تكون جميع الأسطر الجديدة تتضمن المحرفين الخاصين CR+LF، لكن المتصفح لن يضيف أيّة أسطر جديدة من عنده.
إذا لم تُحدَّد قيمة لهذه الخاصية فستكون قيمتها الافتراضية هي soft
.
يجدر بالذكر أنَّ هذه الخاصية أضيفت إلى HTML5، ولم تكن موجودةً فيما سبق.
مثال عن إسناد القيمة hard
إلى الخاصية wrap
:
<textarea name="textarea" cols="10" wrap="hard">اكتب نصًا هنا</textarea>
ملاحظات
إعادة تحجيم العنصر <textarea>
يمكن التحكم بتحجيم العنصر <textarea>
باستخدام الخاصية resize
، إذا إنَّ إعادة التحجيم مفعلة افتراضيًا، ويمكنك تعطيلها باستخدام قاعدة CSS الآتية:
textarea {
resize: none;
}
التفاعل مع CSS
أما بالنسبة إلى CSS، فالعنصر <textarea>
هو عنصر مُستبدَل (replaced element)، ولا تُعرِّف مواصفة HTML أين يكون خط الأساس (baseline) للعنصر <textarea>
، لذا سيستعمل كل متصفح مكانًا مختلفًا؛ وبالتالي لا يُنصَح باستخدام القيمة baseline
للخاصية vertical-align
في CSS، لأن سلوكها غير متوقع.
يجدر بالذكر أنَّ العنصر <textarea>
له أبعاد صافية، مثل الصور النقطية (<img>
).
التنسيق الافتراضي
تختلف المتصفحات في طريقة عرضها للعنصر <textarea>
، لكنها تشترك بضبط الخاصية display
إلى inline-block
، وتغيير المؤشر cursor
إلى text
، وتغيير عائلة النص font-family
إلى monospace
. أما بقية الخاصيات (مثل الإطار border
، والخلفية background
، والحواشي padding
، وغيرها...) فهي تختلف بين المتصفحات.
مصادر ومواصفات
- معيار HTML Living Standard.
- مواصفة HTML5.
- مواصفة HTML 4.01.