Rumah >hujung hadapan web >tutorial js >Bagaimanakah saya boleh menatal div secara automatik ke elemen tertentu di dalamnya tanpa menatal keseluruhan halaman?

Bagaimanakah saya boleh menatal div secara automatik ke elemen tertentu di dalamnya tanpa menatal keseluruhan halaman?

DDD
DDDasal
2024-10-29 10:24:30677semak imbas

How can I automatically scroll a div to a specific element within it without scrolling the entire page?

Menatal ke Elemen dalam Div

Anda menyasarkan untuk memprogramkan div yang ditatal untuk menatal secara automatik ke elemen di dalamnya apabila mengklik. Menggunakan scrollIntoView(true) nampaknya menatal seluruh halaman, membuatkan anda tertanya-tanya.

Penyelesaian:

Untuk menangani isu ini, anda perlu menentukan offset teratas bagi elemen sasaran relatif kepada induknya, bekas div menatal. Ini dicapai melalui:

<code class="js">var myElement = document.getElementById('element_within_div');
var topPos = myElement.offsetTop;</code>

Pos teratas kini mengandungi jarak piksel antara bahagian atas div dan elemen yang anda mahu kelihatan.

Seterusnya, arahkan div untuk menatal ke lokasi tersebut menggunakan scrollTop :

<code class="js">document.getElementById('scrolling_div').scrollTop = topPos;</code>

Dalam Prototaip JS, ini diterjemahkan kepada:

<code class="js">var posArray = $('element_within_div').positionedOffset();
$('scrolling_div').scrollTop = posArray[1];</code>

Tindakan ini menatal div untuk menjajarkan elemen yang ditentukan di bahagian atas, atau sedekat mungkin jika menatal ' t izin sampai ke puncak.

Atas ialah kandungan terperinci Bagaimanakah saya boleh menatal div secara automatik ke elemen tertentu di dalamnya tanpa menatal keseluruhan halaman?. 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