首頁 > web前端 > js教程 > 如何實現無滾動條動態Textarea高度調整?

如何實現無滾動條動態Textarea高度調整?

Linda Hamilton
發布: 2024-10-23 13:32:30
原創
912 人瀏覽過

How to Implement Dynamic Textarea Height Adjustment without Scrollbars?

重訪Textarea自動高度

問題:

很多開發者都遇過需要調整的情況動態調整文字區域的高度以適應其中的內容。這不僅增強了用戶體驗,還消除了不必要的滾動條。

解決方案:

實現此目的的一種方法是使用純 JavaScript。以下是一個有效調整文字區域高度的程式碼片段:

<code class="javascript">function auto_grow(element) {
  element.style.height = "5px";
  element.style.height = (element.scrollHeight) + "px";
}</code>
登入後複製

在此程式碼中:

  • 元素是要調整的文字區域。
  • 初始高度設定為一個較小的值(5px)以允許精確計算。
  • scrollHeight 屬性傳回文字區域內容的高度,包括隱藏的溢位。
  • 將高度設定為滾動高度動態調整以適應內容。

要在 CSS 和 HTML 中實現此功能:

<code class="css">textarea {
  resize: none;
  overflow: hidden;
  min-height: 50px;
  max-height: 100px;
}</code>
登入後複製
<code class="html"><textarea oninput="auto_grow(this)"></textarea></code>
登入後複製
  • resize: none;防止使用者調整文字區域的大小。
  • 溢位:隱藏;隱藏超出設定高度的任何多餘內容。
  • min-height 和 max-height 定義最小和最大高度限制。
  • 每當文字區域中的輸入發生變化時,oninput 事件就會觸發auto_grow 函數.

此解決方案可確保文字區域的高度與其包含的內容相匹配,從而在沒有滾動條的情況下提供改進的用戶體驗。

以上是如何實現無滾動條動態Textarea高度調整?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板