Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> Javascript

ขยาย Textarea อัตโนมัติด้วย JavaScript ใน CSS


เมื่อใช้ JavaScript เราสามารถตั้งค่าองค์ประกอบ Textarea ให้เติบโตไปพร้อมกับเนื้อหาโดยอัตโนมัติ

ตัวอย่างต่อไปนี้แสดงให้เห็นว่าเราจะบรรลุสถานการณ์ข้างต้นได้อย่างไร

ตัวอย่าง

<!DOCTYPE html>
<html>
<head>
<style>
* {
   margin: 3%;
   color: navy;
   font-size: 1.2em;
}
#ta {
   padding: 2%;
   resize: none;
   width: 330px;
   min-height: 80px;
   overflow: hidden;
   box-sizing: border-box;
}
</style>
</head>
<body>
<form>
<label for="ta">Cool TextArea</label>
<textarea id="ta"></textarea>
</form>
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
<script>
$("#ta").on('input', function() {
   var scroll_height = $("#ta").get(0).scrollHeight;
   $("#ta").css('height', scroll_height + 'px');
});
</script>
</body>
</html>

ผลลัพธ์

สิ่งนี้จะให้ผลลัพธ์ดังต่อไปนี้ -

ขยาย Textarea อัตโนมัติด้วย JavaScript ใน CSS

ขยาย Textarea อัตโนมัติด้วย JavaScript ใน CSS

ตัวอย่าง

<!DOCTYPE html>
<html>
<head>
<style>
div {
   margin: 3%;
   overflow-y: scroll;
}
#ta {
   padding: 2%;
   resize: none;
   width: 333px;
   min-height: 90px;
   overflow: hidden;
   box-sizing: border-box;
   font-size: 1.5em;
}
</style>
</head>
<body>
<div>
<textarea id="ta"></textarea>
</div>
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
<script>
$("#ta").on('input', function() {
   var scroll_height = $("#ta").get(0).scrollHeight;
   $("#ta").css('height', scroll_height + 'px');
});
</script>
</body>
</html>

ผลลัพธ์

สิ่งนี้จะให้ผลลัพธ์ดังต่อไปนี้ -

ขยาย Textarea อัตโนมัติด้วย JavaScript ใน CSS