html 文本域固定死高度,根据文本域(Textarea)内容自动调整高度

html部分

style="padding: 16px; line-height: 1.5;">

js部分(function() {

function adjustHeight(textareaElement, minHeight) {

// compute the height difference which is caused by border and outline

var outerHeight = parseInt(window.getComputedStyle(el).height, 10);

var diff = outerHeight - el.clientHeight;

// set the height to 0 in case of it has to be shrinked

el.style.height = 0;

// set the correct height

// el.scrollHeight is the full height of the content, not just the visible part

el.style.height = Math.max(minHeight, el.scrollHeight + diff) + 'px';

}

// we use the "data-adaptheight" attribute as a marker

var textAreas = document.querySelectorAll('textarea[data-adaptheight]');

// iterate through all the textareas on the page

for (var i = 0, l = textAreas.length; i < l; i++) {

var el = textAreas[i];

// we need box-sizing: border-box, if the textarea has padding

el.style.boxSizing = el.style.mozBoxSizing = 'border-box';

// we don't need any scrollbars, do we? :)

el.style.overflowY = 'hidden';

// the minimum height initiated through the "rows" attribute

var minHeight = el.scrollHeight;

el.addEventListener('input', function() {

adjustHeight(el, minHeight);

});

// we have to readjust when window size changes (e.g. orientation change)

window.addEventListener('resize', function() {

adjustHeight(el, minHeight);

});

// we adjust height to the initial content

adjustHeight(el, minHeight);

}

}());

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值