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
Lepaskan: 2024-10-29 10:24:30
asal
712 orang telah melayarinya

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>
Salin selepas log masuk

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>
Salin selepas log masuk

Dalam Prototaip JS, ini diterjemahkan kepada:

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

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!

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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan