DHTML 中的绝对定位

嗨一会有何不可

嗨一会有何不可

2016-02-19 11:48

关注图老师设计创意栏目可以让大家能更好的了解电脑,知道有关于电脑的更多有趣教程,今天给大家分享DHTML 中的绝对定位教程,希望对大家能有一点小小的帮助。
下面的东西显示了在复杂的情况下,
怎样最好地在一个Element的旁边显示某个DIV。
当然,你可以滚动窗口,使这个按纽靠窗口的 左/上/右/下 的情况,观察菜单的弹出方位。
全部代码:
代码如下:
table border=1 cellpadding=8 cellspacing=0 
trtdtable1/tdtdtable1/td/tr 
trtdtable1/tdtd 
 div id=div1 style='position:absolute;background-color:wheat;padding:4px;' 
 div1 start 
 div id=div1button style='border:outset 2px;background-color:threedface;color:red;font-weight:bold;cursor:hand;padding:4px;' 
  ClickMe 
 /div 
 div1 end 
 /div 
 /td/tr 
/table 
div style='height:100px'-/div 
table border=1 cellpadding=8 cellspacing=0 
trtdtable2/tdtdtable2/td/tr 
trtdtable2/tdtd 
 div id=div2 style='position:relative;left:24px;background-color:wheat;' 
 div2 start 
 div id=div2menu style='display:none;position:absolute;background-color:lightgrey;height:200px;width:120px;border:outset 1px;padding:4px' 
  div2menubr 
  div2menubr 
  div2menubr 
  div2menubr 
  div2menubr 
 /div 
 div2 end 
 /div 
 /td/tr 
/table 
script language='jscript' 
//get the position of a element ( by the scroll offset ) 
function LostinetWebGetScrollPostion(e) 

 var b=e.document.body; 
 if(e==b)return {left:0,top:0}; 
 with(e.getBoundingClientRect()) 
 { 
  return {left:b.scrollLeft+left,top:b.scrollTop+top}; 
 } 

//get the position of a element ( by the client offset ) 
function LostinetWebGetClientPosition(e) 

 var b=e.document.body; 
 if(e==b)return {left:-b.scrollLeft,top:-b.scrollTop}; 
 with(e.getBoundingClientRect()) 
 { 
  return {left:left-b.clientLeft,top:top-b.clientTop}; 
 } 

//get absolute or relative parent 
function LostinetWebGetStandParent(e) 

 for(var p=e.parentElement;p!=null;p=p.parentElement) 
 { 
  var sp=p.currentStyle.position; 
  if(sp=='absolute'||sp=='relative') 
   return p; 
 } 
 return e.document.body; 

//calc the position of floate that relative to e 
function LostinetWebCalcPosition(floate,e) 

 var epos=LostinetWebGetScrollPostion(e); 
 var spos=LostinetWebGetScrollPostion(LostinetWebGetStandParent(floate)); 
 var s=LostinetWebGetStandParent(floate); 
 return {left:epos.left-spos.left-s.clientLeft,top:epos.top-spos.top-s.clientTop}; 

//get the best position to put the floate 
function LostinetWebAdjustMirror(floate,e,pos) 

 //c:Client,f:floate,e:e,p:floate's StandParent,m:Mirror 
 var cw=e.document.body.clientWidth; 
 var ch=e.document.body.clientHeight; 
 var fw=floate.offsetWidth; 
 var fh=floate.offsetHeight; 
 var ew=e.offsetWidth; 
 var eh=e.offsetHeight; 
 var ecpos=LostinetWebGetClientPosition(e); 
 var empos={left:ecpos.left+ew/2,top:ecpos.top+eh/2}; 
 var pcpos=LostinetWebGetClientPosition(LostinetWebGetStandParent(floate)); 
 var fcpos=LostinetWebGetClientPosition(floate); 
 var fmpos={left:pcpos.left+pos.left+fw/2,top:pcpos.top+pos.top+fh/2}; 
 //left--right 
 if( (fmpos.leftempos.left) ? ((fmpos.left-fw/20)&&((empos.left*2-fmpos.left)+fw/2=cw)) : ((fmpos.left+fw/2cw)&&((empos.left*2-fmpos.left)-fw/2=0)) ) 
  fmpos.left=empos.left*2-fmpos.left; 
 //top--bottom 
 if( (fmpos.topempos.top) ? ((fmpos.top-fh/20)&&((empos.top*2-fmpos.top)+fh/2=ch)) : ((fmpos.top+fh/2ch)&&((empos.top*2-fmpos.top)-fh/2=0)) ) 
  fmpos.top=empos.top*2-fmpos.top; 
 pos.left=fmpos.left-pcpos.left-fw/2; 
 pos.top=fmpos.top-pcpos.top-fh/2; 

document.attachEvent('onclick',function f() 

 if(div1button.contains(event.srcElement))return; 
 if(div2menu.contains(event.srcElement))return; 
 div2menu.runtimeStyle.display='none'; 
}); 
function div1button.onclick() 

 div2menu.runtimeStyle.display='block'; 
 var pos=LostinetWebCalcPosition(div2menu,div1button); 
 pos.top+=div1button.offsetHeight; 
 LostinetWebAdjustMirror(div2menu,div1button,pos); 
 div2menu.runtimeStyle.left=pos.left; 
 div2menu.runtimeStyle.top=pos.top; 

/script 
展开更多 50%)
分享

猜你喜欢

DHTML 中的绝对定位

Web开发
DHTML 中的绝对定位

CSS网页中的相对定位与绝对定位

Web开发
CSS网页中的相对定位与绝对定位

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

CSS中关于相对定位和绝对定位

Web开发
CSS中关于相对定位和绝对定位

CSS层的应用及其定位(绝对定位和相对定位)

Web开发
CSS层的应用及其定位(绝对定位和相对定位)

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

绝对定位(absolute)和浮动定位(float)

Web开发
绝对定位(absolute)和浮动定位(float)

CSS教程:position 绝对定位的问题

Web开发
CSS教程:position 绝对定位的问题

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

鼠标放在放在输入框上面提示效果

鼠标放在放在输入框上面提示效果

QQ禁止被查找怎么设置

QQ禁止被查找怎么设置
下拉加载更多内容 ↓