DHTML 中的绝对定位_javascript技巧
下面的东西显示了在复杂的情况下,
怎样最好地在一个Element的旁边显示某个DIV。
当然,你可以滚动窗口,使这个按纽靠窗口的 左/上/右/下 的情况,观察菜单的弹出方位。
全部代码:
table1 | table1 |
table1 | div1 start ClickMe div1 end |
table2 | table2 |
table2 | div2 start div2menu div2menu div2menu div2menu div2menu div2 end |
<script> <BR>//get the position of a element ( by the scroll offset ) <BR>function LostinetWebGetScrollPostion(e) <BR>{ <BR> var b=e.document.body; <BR> if(e==b)return {left:0,top:0}; <BR> with(e.getBoundingClientRect()) <BR> { <BR> return {left:b.scrollLeft+left,top:b.scrollTop+top}; <BR> } <BR>} <BR>//get the position of a element ( by the client offset ) <BR>function LostinetWebGetClientPosition(e) <BR>{ <BR> var b=e.document.body; <BR> if(e==b)return {left:-b.scrollLeft,top:-b.scrollTop}; <BR> with(e.getBoundingClientRect()) <BR> { <BR> return {left:left-b.clientLeft,top:top-b.clientTop}; <BR> } <BR>} <BR>//get absolute or relative parent <BR>function LostinetWebGetStandParent(e) <BR>{ <BR> for(var p=e.parentElement;p!=null;p=p.parentElement) <BR> { <BR> var sp=p.currentStyle.position; <BR> if(sp=='absolute'||sp=='relative') <BR> return p; <BR> } <BR> return e.document.body; <BR>} <BR>//calc the position of floate that relative to e <BR>function LostinetWebCalcPosition(floate,e) <BR>{ <BR> var epos=LostinetWebGetScrollPostion(e); <BR> var spos=LostinetWebGetScrollPostion(LostinetWebGetStandParent(floate)); <BR> var s=LostinetWebGetStandParent(floate); <BR> return {left:epos.left-spos.left-s.clientLeft,top:epos.top-spos.top-s.clientTop}; <BR>} <BR>//get the best position to put the floate <BR>function LostinetWebAdjustMirror(floate,e,pos) <BR>{ <BR> //c:Client,f:floate,e:e,p:floate's StandParent,m:Mirror <BR> var cw=e.document.body.clientWidth; <BR> var ch=e.document.body.clientHeight; <BR> var fw=floate.offsetWidth; <BR> var fh=floate.offsetHeight; <BR> var ew=e.offsetWidth; <BR> var eh=e.offsetHeight; <BR> var ecpos=LostinetWebGetClientPosition(e); <BR> var empos={left:ecpos.left+ew/2,top:ecpos.top+eh/2}; <BR> var pcpos=LostinetWebGetClientPosition(LostinetWebGetStandParent(floate)); <BR> var fcpos=LostinetWebGetClientPosition(floate); <BR> var fmpos={left:pcpos.left+pos.left+fw/2,top:pcpos.top+pos.top+fh/2}; <BR> //left<-->right <BR> if( (fmpos.left<empos.left) ? ((fmpos.left-fw/2<0)&&((empos.left*2-fmpos.left)+fw/2<=cw)) : ((fmpos.left+fw/2>cw)&&((empos.left*2-fmpos.left)-fw/2>=0)) ) <BR> fmpos.left=empos.left*2-fmpos.left; <BR> //top<-->bottom <BR> if( (fmpos.top<empos.top) ? ((fmpos.top-fh/2<0)&&((empos.top*2-fmpos.top)+fh/2<=ch)) : ((fmpos.top+fh/2>ch)&&((empos.top*2-fmpos.top)-fh/2>=0)) ) <BR> fmpos.top=empos.top*2-fmpos.top; <BR> pos.left=fmpos.left-pcpos.left-fw/2; <BR> pos.top=fmpos.top-pcpos.top-fh/2; <BR>} <BR>document.attachEvent('onclick',function f() <BR>{ <BR> if(div1button.contains(event.srcElement))return; <BR> if(div2menu.contains(event.srcElement))return; <BR> div2menu.runtimeStyle.display='none'; <BR>}); <BR>function div1button.onclick() <BR>{ <BR> div2menu.runtimeStyle.display='block'; <BR> var pos=LostinetWebCalcPosition(div2menu,div1button); <BR> pos.top+=div1button.offsetHeight; <BR> LostinetWebAdjustMirror(div2menu,div1button,pos); <BR> div2menu.runtimeStyle.left=pos.left; <BR> div2menu.runtimeStyle.top=pos.top; <BR>} <BR></script>

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Fungsi JavaScript mudah digunakan untuk memeriksa sama ada tarikh sah. fungsi isvaliddate (s) { var bits = s.split ('/'); var d = tarikh baru (bit [2] '/' bits [1] '/' bits [0]); kembali !! (d && (d.getmonth () 1) == bit [1] && d.getdate () == nombor (bit [0])); } // ujian var

Artikel ini membincangkan cara menggunakan jQuery untuk mendapatkan dan menetapkan margin dalaman dan nilai margin elemen DOM, terutama lokasi tertentu margin luar dan margin dalaman elemen. Walaupun ada kemungkinan untuk menetapkan margin dalaman dan luar elemen menggunakan CSS, nilai yang tepat boleh menjadi rumit. // Sediakan $ ("div.header"). css ("margin", "10px"); $ ("div.header"). css ("padding", "10px"); Anda mungkin menganggap kod ini

Artikel ini meneroka sepuluh tab jQuery yang luar biasa dan akordion. Perbezaan utama antara tab dan akordion terletak pada bagaimana panel kandungan mereka dipaparkan dan tersembunyi. Mari kita menyelidiki sepuluh contoh ini. Artikel Berkaitan: 10 JQuery Tab Plugin

Temui sepuluh plugin jQuery yang luar biasa untuk meningkatkan dinamisme dan daya tarikan visual laman web anda! Koleksi ini menawarkan pelbagai fungsi, dari animasi imej ke galeri interaktif. Mari kita meneroka alat yang berkuasa ini: Posting Berkaitan: 1

HTTP-CONSOLE adalah modul nod yang memberi anda antara muka baris arahan untuk melaksanakan arahan HTTP. Ia bagus untuk menyahpepijat dan melihat apa yang sedang berlaku dengan permintaan HTTP anda, tanpa mengira sama ada mereka dibuat terhadap pelayan web, Serv Web

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Coretan kod jQuery berikut boleh digunakan untuk menambah bar skrol apabila kandungan div melebihi kawasan elemen kontena. (Tiada demonstrasi, sila salin terus ke Firebug) // d = dokumen // w = tetingkap // $ = jQuery var contentArea = $ (ini), Wintop = contentArea.scrollTop (), docheight = $ (d) .height (), winheight = $ (w) .height (), Divheight = $ ('#c
