Rumah > hujung hadapan web > tutorial css > Bagaimana untuk Saiz DIV secara Dinamik kepada Kandungan Teks Balut dengan JavaScript?

Bagaimana untuk Saiz DIV secara Dinamik kepada Kandungan Teks Balut dengan JavaScript?

Patricia Arquette
Lepaskan: 2024-10-29 20:36:29
asal
1064 orang telah melayarinya

How to Dynamically Size a DIV to Wrapped Text Content with JavaScript?

Mencapai Saiz DIV Dinamik untuk Teks yang Dibalut Menggunakan JavaScript

Mengecilkan DIV sehingga tahap kandungan teks yang dibalut menggunakan CSS sahaja menimbulkan cabaran. Walau bagaimanapun, JavaScript boleh digunakan untuk mengatasi had ini dan mencapai kelakuan yang diingini.

Dalam contoh kod yang disediakan, elemen DIV ("mengecut") dengan lebar maksimum 130px mempamerkan jidar yang tidak diingini disebabkan oleh pembalut teks . Untuk menangani isu ini, JavaScript digunakan untuk mengira lebar sebenar kandungan yang dibalut dan melaraskan saiz DIV dengan sewajarnya.

<code class="js">const range = document.createRange();
const text = p.childNodes[0];
range.setStartBefore(text);
range.setEndAfter(text);
const clientRect = range.getBoundingClientRect();
p.style.width = `${clientRect.width}px`;</code>
Salin selepas log masuk

Coretan kod ini menggunakan fungsi createRange() untuk menentukan julat yang merangkumi julat yang dibalut teks. Kemudian, getBoundingClientRect() mengira segi empat tepat terikat untuk julat yang ditentukan, dengan berkesan menentukan lebar kandungan teks. Akhirnya, lebar DIV ditetapkan secara dinamik agar sepadan dengan lebar ini, menghasilkan kesesuaian yang selesa di sekeliling teks yang dibalut.

Atas ialah kandungan terperinci Bagaimana untuk Saiz DIV secara Dinamik kepada Kandungan Teks Balut dengan JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan