做一個(gè)能自適應(yīng)高度的textarea的示例代碼
發(fā)布時(shí)間:2019-09-06 16:02:17 作者:卡米撒嗎
我要評(píng)論

這篇文章主要介紹了做一個(gè)能自適應(yīng)高度的textarea的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
方法
1. HTML結(jié)構(gòu):
<div id="container"> <textarea rows="1"></textarea> </div>
2. CSS代碼:
* { padding: 0; margin: 0; } #container { width: 300px; padding: 10px; border: 1px solid #eee; box-sizing: border-box; } textarea { display: block; width: 100%; font-size: 20px; color: #000; line-height: 24px; outline: none; border: none; resize: none; }
3. JS代碼:
var textarea = document.querySelector('textarea') var inpnt = (function () { var baseHeight = null return function () { !baseHeight && (baseHeight = this.scrollHeight) this.rows = 1 var rows = Math.ceil(this.scrollHeight / baseHeight) >= 3 ? 3 : Math.ceil(this .scrollHeight / baseHeight) this.rows = rows } })() textarea.oninput = debounce(inpnt, 100) function debounce(func, delay) { var timer = null return function () { var _this = this var args = arguments timer && clearTimeout(timer) timer = setTimeout(function () { func.apply(_this, args) }, delay) } }
原理
!baseHeight && (baseHeight = this.scrollHeight) this.rows = 1 var rows = Math.ceil(this.scrollHeight / baseHeight) >= 3 ? 3 : Math.ceil(this .scrollHeight / baseHeight) this.rows = rows
第一行 獲取基準(zhǔn)高度 緩存起
第二行 重點(diǎn) 將textarea的rows設(shè)置成1 這樣就能得到當(dāng)前textarea的scrollHeight
第三行 拿到了當(dāng)前textarea的scrollHeight 就可以算出rows
第四行 設(shè)置textarea的rows
通過設(shè)置textarea的rows屬性來改變textarea的高度。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何讓pre和textarea等HTML元素去掉滾動(dòng)條自動(dòng)換行自適應(yīng)文本內(nèi)容高度
這篇文章主要介紹了如何讓pre和textarea等HTML元素去掉滾動(dòng)條自動(dòng)換行自適應(yīng)文本內(nèi)容高度的相關(guān)資料,需要的朋友可以參考下2019-08-01textarea文本域?qū)挾群透叨葁idth及height自動(dòng)適應(yīng)實(shí)現(xiàn)代碼
本文為大家介紹下textarea文本域?qū)挾群透叨龋╳idth、height)如何自動(dòng)適應(yīng)變化處理,下面有個(gè)不錯(cuò)的示例,感興趣的朋友可以參考下2013-12-30div模擬textarea文本域?qū)崿F(xiàn)高度自適應(yīng)效果代碼
textarea標(biāo)簽為表單元素,一般用在多行文字的輸入。在web應(yīng)用上常見的是評(píng)論輸入框,微博信息輸入框等。2010-12-27css textarea 高度自適應(yīng),無滾動(dòng)條
用css控制textarea文本域的高度隨內(nèi)容的變化而變化,不出現(xiàn)滾動(dòng)條.2009-07-11