随笔-86  评论-767  文章-3  trackbacks-3

在Web中经常碰到链接提示文字效果,就是当鼠标经过URL链接时,立刻弹出一个提示层(DIV),提示链接内容等等相关文字.虽然知道是用隐藏DIV实现的,不过一直不知道怎么弄.昨天搜到一个JS文件,可以轻松搞定.帖出来,收藏一下.
JS文件代码如下(mouse_on_title.js):

<!--
//***********默认设置定义.*********************
tPopWait=50;  //停留tWait豪秒后显示提示。
tPopShow=6000;  //显示tShow豪秒后关闭提示
showPopStep=20;
popOpacity=95;
fontcolor="#000000";
bgcolor="#EDEDED";
bordercolor="#007db5";

//***************内部变量定义*****************
sPop=null;curShow=null;tFadeOut=null;tFadeIn=null;tFadeWaiting=null;

document.write("<style type='text/css'id='defaultPopStyle'>");
document.write(".cPopText {  background-color: " + bgcolor + ";color:" + fontcolor + "; border: 1px " + bordercolor + " solid;font-color: font-size: 12px; padding-right: 4px; padding-left: 4px; height: 20px; padding-top: 2px; padding-bottom: 2px; filter: Alpha(Opacity=0)}");
document.write("</style>");
document.write("<div id='dypopLayer' style='position:absolute;z-index:1000;' class='cPopText'></div>");


function showPopupText(){
var o=event.srcElement;
 MouseX=event.x;
 MouseY=event.y;
 if(o.alt!=null && o.alt!=""){o.dypop=o.alt;o.alt=""};
        if(o.title!=null && o.title!=""){o.dypop=o.title;o.title=""};
 if(o.dypop!=sPop) {
   sPop=o.dypop;
   clearTimeout(curShow);
   clearTimeout(tFadeOut);
   clearTimeout(tFadeIn);
   clearTimeout(tFadeWaiting); 
   if(sPop==null || sPop=="") {
    dypopLayer.innerHTML="";
    dypopLayer.style.filter="Alpha()";
    dypopLayer.filters.Alpha.opacity=0; 
    }
   else {
    if(o.dyclass!=null) popStyle=o.dyclass
     else popStyle="cPopText";
    curShow=setTimeout("showIt()",tPopWait);
   }
   
 }
}

function showIt(){
  dypopLayer.className=popStyle;
  dypopLayer.innerHTML=sPop;
  popWidth=dypopLayer.clientWidth;
  popHeight=dypopLayer.clientHeight;
  if(MouseX+12+popWidth>document.body.clientWidth) popLeftAdjust=-popWidth-24
   else popLeftAdjust=0;
  if(MouseY+12+popHeight>document.body.clientHeight) popTopAdjust=-popHeight-24
   else popTopAdjust=0;
  dypopLayer.style.left=MouseX+12+document.body.scrollLeft+popLeftAdjust;
  dypopLayer.style.top=MouseY+12+document.body.scrollTop+popTopAdjust;
  dypopLayer.style.filter="Alpha(Opacity=0)";
  fadeOut();
}

function fadeOut(){
 if(dypopLayer.filters.Alpha.opacity<popOpacity) {
  dypopLayer.filters.Alpha.opacity+=showPopStep;
  tFadeOut=setTimeout("fadeOut()",1);
  }
  else {
   dypopLayer.filters.Alpha.opacity=popOpacity;
   tFadeWaiting=setTimeout("fadeIn()",tPopShow);
   }
}

function fadeIn(){
 if(dypopLayer.filters.Alpha.opacity>0) {
  dypopLayer.filters.Alpha.opacity-=1;
  tFadeIn=setTimeout("fadeIn()",1);
  }
}
document.onmouseover=showPopupText;
-->

应用的时候,在页面的<head></head>之间加入:
<SCRIPT language=javascript src="mouse_on_title.js"></SCRIPT>

在需要提示层的链接中加入title属性,比如:
//<a href=”目标” title=”提示文字内容”>测试</a>
其实如果不加上述JS文件,提示层效果也是可以出来的.就是速度比较慢,提示层效果比较单调而已.

posted on 2005-01-26 10:43 eamoi 阅读(2153) 评论(5)  编辑  收藏 所属分类: JS/VBS/HTML

评论:
# re: 链接提示文字的实现 2005-04-05 10:34 | sdf
vb   回复  更多评论
  
# re: 链接提示文字的实现 2005-11-14 22:27 | tdk84e
163不少地方都用到了这样的功能,如邮箱,JS代码很不错
8-)  回复  更多评论
  
# re: 链接提示文字的实现 2006-02-15 14:24 | xiehuiqi
当页面很短(没有滚动条时),提示层可以显示在离鼠标很近的位置
可是当页面很长,一旦拖动滚动条到页面下部,则提示层的位置到上部不可见区域去了
这段代码我很熟悉,因为很多人拷贝
但是这个问题我至今没见到有解决的(就使用这段代码而言)  回复  更多评论
  
# re: 链接提示文字的实现 2006-04-12 12:52 | ghyghost
楼上的问题和我一样,,

我也遇到过,后来不用 了。  回复  更多评论
  
# re: 链接提示文字的实现[未登录] 2008-01-10 09:47 | Kenny
还不错,But only IE :(  回复  更多评论
  

只有注册用户登录后才能发表评论。


网站导航: