欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript 實用的文字鏈提示框效果

 更新時間:2010年06月30日 15:08:43   投稿:mdxy-dxy  
鼠標滑過文章中的鏈接文字,要在相應位置彈出提示框,提示框的樣式由css來控制,高度自適應;鼠標可以點擊提示框的中的鏈接,滑離提示框時,框自動消失

效果要基本實現(xiàn)以下功能:
(1)鼠標滑過文章中的鏈接文字,要在相應位置彈出提示框,提示框的樣式由css來控制,高度自適應;鼠標可以點擊提示框的中的鏈接,滑離提示框時,框自動消失;
(2)把提示框的位置控制在文本域范圍之內(nèi),如果鏈接文字處在文本域左側,提示框要居右顯示,使其不會出離文本域;反之,如果鏈接文字處在文本域右側,提示框要居左顯示;
(3)如果文本域內(nèi)容很多,而鏈接文字恰巧處于瀏覽器底部,為了使提示框不出離于瀏覽器的可視范圍,提示框的位置要自動調(diào)整到鏈接文字的上面;

1.css

復制代碼 代碼如下:

.main{width:950px; border:#9C3 1px solid; margin:0 auto; padding:15px; background-color:#fff; line-height:25px;font-size:14px; position:relative;}
span{border:#70bce4 2px solid; display:block; position:absolute; background-color:#FFF; padding:5px 10px; font-size:12px; width:200px; display:none;}
.cur{color:#900;}

2.js
復制代碼 代碼如下:

//獲取對象元素的函數(shù);
function $a(id,tag){var re=(id&&typeof id!="string")?id:document.getElementById(id);if(!tag){return re;}else{return re.getElementsByTagName(tag);}}
function tips(){
//獲取文本域中的a元素列表;
var article=$a("article","a")
for(i=0;i<article.length;i++){
//遍歷a元素,不包含類"cur"的a元素將不會執(zhí)行之后的代碼;
if(article[i].className.indexOf("cur")==-1) continue;
article[i].onmouseover=function(e){
//獲取鼠標指針在瀏覽器可視區(qū)域的坐標,不受文檔內(nèi)容影響;
var e=e||event;
posX = e.clientX;
posY = e.clientY;
//獲取瀏覽器可視區(qū)域高度;
var bodyhe=document.documentElement.clientHeight;
var parwidth=$a("article").offsetWidth;
var tipbox=get_nextSibling(this);
var boxlist=$a("article","span")
//設置文本區(qū)域中的span提示框均為隱藏狀態(tài);
for(j=0;j<boxlist.length;j++){
boxlist[j].style.display="none";
boxlist[j].innerHTML="調(diào)入后臺數(shù)據(jù)"
}
//設置當前的提示框顯示;
tipbox.style.display="block";
var w=tipbox.offsetWidth-this.offsetWidth;
/*
以id為article的div添加了相對定位position:relative,所以它已經(jīng)是提示框的父級;
控制彈出框的顯示位置;
*/
tipbox.style.left=(this.offsetLeft>parwidth/2?this.offsetLeft-w:this.offsetLeft)+"px";
tipbox.style.top=(posY+tipbox.offsetHeight>bodyhe?this.offsetTop-tipbox.offsetHeight:document.all?this.offsetTop+15:this.offsetTop+this.offsetHeight)+"px";
tipbox.onmouseover=function(){this.style.display="block";}
tipbox.onmouseout=this.onmouseout=function(){tipbox.style.display="none";}
}
}
}
//獲取對象元素的下一個標簽節(jié)點;
function get_nextSibling(n){
var x=n.nextSibling;
while (x.nodeType!=1){
x=x.nextSibling;
}
return x;
}

貼出源文件代碼 感興趣的朋友可以測試一下,有問題可留言 @&@
復制代碼 代碼如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>提示框效果</title>
<style type="text/css">
.main{width:950px; border:#9C3 1px solid; margin:0 auto; padding:15px; background-color:#fff; line-height:25px;font-size:14px; position:relative;}
span{border:#70bce4 2px solid; display:block; position:absolute; background-color:#FFF; padding:5px 10px; font-size:12px; width:200px; display:none;}
.cur{color:#900;}
</style>
</head>
<body onload="tips();">
<br />
<br />
<br />
<br />
<div class="main" id="article">
本人的曖昧態(tài)度也為此事件更增添了一份迷霧。
</div>
<script type="text/javascript">
function $a(id,tag){var re=(id&&typeof id!="string")?id:document.getElementById(id);if(!tag){return re;}else{return re.getElementsByTagName(tag);}}
function tips(){
var article=$a("article","a")
for(i=0;i<article.length;i++){
if(article[i].className.indexOf("cur")==-1) continue;
article[i].onmouseover=function(e){
var e=e||event;
posX = e.clientX;
posY = e.clientY;
var bodyhe=document.documentElement.clientHeight;
var parwidth=$a("article").offsetWidth;
var tipbox=get_nextSibling(this);
var boxlist=$a("article","span")
for(j=0;j<boxlist.length;j++){
boxlist[j].style.display="none";
boxlist[j].innerHTML="調(diào)入后臺數(shù)據(jù)"
}
tipbox.style.display="block";
var w=tipbox.offsetWidth-this.offsetWidth;
tipbox.style.left=(this.offsetLeft>parwidth/2?this.offsetLeft-w:this.offsetLeft)+"px";
tipbox.style.top=(posY+tipbox.offsetHeight>bodyhe?this.offsetTop-tipbox.offsetHeight:document.all?this.offsetTop+15:this.offsetTop+this.offsetHeight)+"px";
tipbox.onmouseover=function(){this.style.display="block";}
tipbox.onmouseout=this.onmouseout=function(){tipbox.style.display="none";}
}
}
}
function get_nextSibling(n){
var x=n.nextSibling;
while (x.nodeType!=1){
x=x.nextSibling;
}
return x;
}
</script>
</body>
</html>

相關文章

  • JS旋轉的彩色文字輪轉特效

    JS旋轉的彩色文字輪轉特效

    JavaScript完成的文字效果,不停旋轉的文字特效,給旋轉到當前的文字增加炫麗的彩色效果,還行吧,偶比較喜歡的效果,里面的很多參數(shù)都是可調(diào)的。
    2009-11-11
  • JavaScript 仿歌詞效果

    JavaScript 仿歌詞效果

    這是一個文字疊加滾動效果,當然離不開JavaScript了,看上去像MTV的歌詞效果,用兩種顏色的文字疊加形成的效果,用Js去控制時間和顏色,這個當然你可以自己修改噢!
    2009-10-10
  • Marquee配合DIV實現(xiàn)的文字滾動效果代碼

    Marquee配合DIV實現(xiàn)的文字滾動效果代碼

    Marquee走馬燈標簽,用它能實現(xiàn)各種各樣的滾動,而只需修改個別參數(shù)就行了,在WEB標準時代,Marquee的作用當然也應該與時俱進了.
    2009-11-11
  • JS、CSS文字切換,定時交替,代碼精簡

    JS、CSS文字切換,定時交替,代碼精簡

    圖片切換很流行,文字切換也很實用哦,而且用CSS與JavaScript配合,避免純JS實現(xiàn)時把文字寫進JavaScript代碼里,修改不方便,本款可以說是方便,簡單,效果實用,兼容性好.
    2009-10-10
  • Js文字背景行如流水特效

    Js文字背景行如流水特效

    行如流水的Js文字背景特效,本人比較喜歡的效果,文字的背景像流水線一樣,不斷的循環(huán)變化,很漂亮哦。
    2009-10-10
  • 仿打字特效的JS逐字出現(xiàn)的信息文字

    仿打字特效的JS逐字出現(xiàn)的信息文字

    JavaScript編寫的文字特效,看似打字的效果,讓文字逐個出現(xiàn),你可以以這個為基礎給你心愛的人寫一段祝福的語,這的確挺合適。
    2009-10-10
  • JavaScript數(shù)組應用 可依次讀取的公告欄文字

    JavaScript數(shù)組應用 可依次讀取的公告欄文字

    一個JavaScript數(shù)組的應用例子,我們將文字存儲于數(shù)組中,然后用循環(huán)依次輸出這些文字,像一條一條的公告一樣,不過現(xiàn)在都不這么用了,可以學習JS數(shù)組,算是一個實例參考。
    2009-10-10
  • javascript 灑脫飄動的文字

    javascript 灑脫飄動的文字

    飄動的文字,看著還挺自在、灑脫,網(wǎng)上經(jīng)常見的東西,原來是這么實現(xiàn)的,奉獻給大家哦。
    2009-10-10
  • javascript跑馬燈懸停放大效果實現(xiàn)代碼

    javascript跑馬燈懸停放大效果實現(xiàn)代碼

    用過qq空間的朋友應該對這個很熟悉吧,效果蠻炫的,不過它們是用flash實現(xiàn)的,那么javascript可不可以呢,需要的朋友可以了解下
    2012-12-12
  • 讓鏈接必須按先后順序點擊的JS代碼

    讓鏈接必須按先后順序點擊的JS代碼

    讓鏈接必須按先后順序點擊的JS代碼,用到廣告上面比較好,有不少的文字或圖片廣告有類似效果,點鏈接的時候需要按順序,請注意鏈接地址,寫在JS代碼里的是真正需要的地址。
    2009-10-10

最新評論