隨筆-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 閱讀(2168) 評論(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 :(  回復  更多評論
            
          主站蜘蛛池模板: 横峰县| 含山县| 柏乡县| 林甸县| 平陆县| 屏山县| 依安县| 安阳市| 库尔勒市| 邹城市| 沐川县| 石景山区| 石门县| 汉寿县| 通许县| 沂水县| 商丘市| 泰来县| 秦安县| 竹北市| 汉源县| 珠海市| 海安县| 都兰县| 高唐县| 霸州市| 武宣县| 梅河口市| 琼结县| 庆安县| 康定县| 南昌市| 石泉县| 枞阳县| 高州市| 玉溪市| 石渠县| 岗巴县| 湟中县| 西贡区| 平顺县|