文字自動換行的實現方法,div文字自動換行

前端–輸入框換行,高度自適應

最近項目遇到一個說小不小說大不大的問題,輸入框要自動換行,並且高度還得自適應,我試了幾種方式,

1.input 輸入,input不能換行,上網查詢了說將css設為word-break: break-all; word-wrap:break-word;也是無效的。

2.div 設置contenteditable=”true”屬性,這種方法可以實現輸入內容自動換行,並且自適應高度,但是項目需要光標從邊輸入,我試過text-align:right是無效的。所以這種方式也不行。

3.textarea,文本輸入框,想想這個應該可以了吧,文本輸入框是可以內容自動換行,可是高度怎麼都是固定的啊。我還是沒解決。百度吧,終於找到解決辦法啦。

最後遇到一個光標在placeholder提示文字上面,解決辦法:#
textarea::-webkit-input-placeholder{ padding-right: 4px;}

<!DOCTYPE html>

<html>

<head>

<meta charset=”utf-8″>

<title></title>

<style>

#textarea {

display: block;

margin:0 auto;

overflow: hidden;

width: 550px;

font-size: 14px;

height: 18px;

line-height: 24px;

padding:2px;

text-align: right;

}

textarea {

outline: 0 none;

border-color: rgba(82, 168, 236, 0.8);

box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.1), 0 0 8px rgba(82, 168, 236, 0.6);

}

</style>

</head>

<body>

<textarea id=”textarea” placeholder=”回復內容”></textarea>

<script>

var autoTextarea = function (elem, extra, maxHeight) {

extra = extra || 0;

var isFirefox = !!document.getBoxObjectFor || ‘mozInnerScreenX’ in window,

isOpera = !!window.opera && !!window.opera.toString().indexOf(‘Opera’),

addEvent = function (type, callback) {

elem.addEventListener ?

elem.addEventListener(type, callback, false) :

elem.attachEvent(‘on’ + type, callback);

},

getStyle = elem.currentStyle ? function (name) {

var val = elem.currentStyle[name];

if (name === ‘height’ && val.search(/px/i) !== 1) {

var rect = elem.getBoundingClientRect();

return rect.bottom – rect.top –

parseFloat(getStyle(‘paddingTop’)) –

parseFloat(getStyle(‘paddingBottom’)) + ‘px’;

};

return val;

} : function (name) {

return getComputedStyle(elem, null)[name];

},

minHeight = parseFloat(getStyle(‘height’));

elem.style.resize = ‘none’;

var change = function () {

var scrollTop, height,

padding = 0,

style = elem.style;

if (elem._length === elem.value.length) return;

elem._length = elem.value.length;

if (!isFirefox && !isOpera) {

padding = parseInt(getStyle(‘paddingTop’)) + parseInt(getStyle(‘paddingBottom’));

};

scrollTop = document.body.scrollTop || document.documentElement.scrollTop;

elem.style.height = minHeight + ‘px’;

if (elem.scrollHeight > minHeight) {

if (maxHeight && elem.scrollHeight > maxHeight) {

height = maxHeight – padding;

style.overflowY = ‘auto’;

} else {

height = elem.scrollHeight – padding;

style.overflowY = ‘hidden’;

};

style.height = height + extra + ‘px’;

scrollTop += parseInt(style.height) – elem.currHeight;

document.body.scrollTop = scrollTop;

document.documentElement.scrollTop = scrollTop;

elem.currHeight = parseInt(style.height);

};

};

addEvent(‘propertychange’, change);

addEvent(‘input’, change);

addEvent(‘focus’, change);

change();

};

</script>

<script>

var text = document.getElementById(“textarea”);

autoTextarea(text);// 調用

</script>

</body>

</html>

原創文章,作者:投稿專員,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/229888.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
投稿專員的頭像投稿專員
上一篇 2024-12-10 13:16
下一篇 2024-12-10 13:16

相關推薦

發表回復

登錄後才能評論