做一個能自適應(yīng)高度的textarea的示例代碼
發(fā)布時間:2019-09-06 16:02:17 作者:卡米撒嗎
我要評論
這篇文章主要介紹了做一個能自適應(yīng)高度的textarea的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(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)高度 緩存起
第二行 重點 將textarea的rows設(shè)置成1 這樣就能得到當(dāng)前textarea的scrollHeight
第三行 拿到了當(dāng)前textarea的scrollHeight 就可以算出rows
第四行 設(shè)置textarea的rows
通過設(shè)置textarea的rows屬性來改變textarea的高度。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何讓pre和textarea等HTML元素去掉滾動條自動換行自適應(yīng)文本內(nèi)容高度
這篇文章主要介紹了如何讓pre和textarea等HTML元素去掉滾動條自動換行自適應(yīng)文本內(nèi)容高度的相關(guān)資料,需要的朋友可以參考下2019-08-01textarea文本域?qū)挾群透叨葁idth及height自動適應(yīng)實現(xiàn)代碼
本文為大家介紹下textarea文本域?qū)挾群透叨龋╳idth、height)如何自動適應(yīng)變化處理,下面有個不錯的示例,感興趣的朋友可以參考下2013-12-30div模擬textarea文本域?qū)崿F(xiàn)高度自適應(yīng)效果代碼
textarea標(biāo)簽為表單元素,一般用在多行文字的輸入。在web應(yīng)用上常見的是評論輸入框,微博信息輸入框等。2010-12-27- 用css控制textarea文本域的高度隨內(nèi)容的變化而變化,不出現(xiàn)滾動條.2009-07-11

