Rumah  >  Artikel  >  hujung hadapan web  >  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
Patricia Arquetteasal
2024-10-29 20:36:291019semak imbas

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>

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!

Kenyataan:
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