首頁  >  文章  >  web前端  >  JS實作滑鼠經過好友清單中的好友頭像時顯示資料卡的效果_javascript技巧

JS實作滑鼠經過好友清單中的好友頭像時顯示資料卡的效果_javascript技巧

WBOY
WBOY原創
2016-05-16 16:42:441176瀏覽

基於專案的需要,需要製作出如下的一種頁面效果:當使用者滑鼠經過好友清單中好友頭像時,顯示該好友的基本資料,其實也就是類似QQ客戶端的那種功能。

網路上找了很多程式碼,基本上都實現了滑鼠懸浮之後彈出div,離開之後馬上就消失了。還有些純CSS的程式碼實現了這樣的效果,但是對我沒用,我需要的是JS的(因為我的資料還要透過Ajax取得),而且滑鼠離開後不能馬上隱藏,這個div上還有功能入口。這個頁面效果折騰了我一天,由此可見我的JS和CSS技術有待提高...

搜尋了好久,終於發現了可行的2個思路如下,這2個方法有個例子,不是我寫的,我也沒用到,轉過來分享一下,演示地址。我的方法參考了方法B的思路。

方法A:

把浮動div和觸發元素a放於同一個父級元素內,滑鼠經過父級元素時觸發顯示。這樣滑鼠移動到div時仍然 處於該父級元素內,則div不會隱藏。

方法B:

滑鼠經過a時彈出div,滑鼠離開a時設定計時器用來關閉div,如果滑鼠移到div後則清除計時器。
—————————————————————————————————————————————————— ———————————————————————————

我這個方法就是採用了上面方法B的思想,當用戶離開觸發事件的圖像後,資料卡div要延時3秒才後關閉,用戶擁有足夠的時間進行相應的操作,當用戶點擊其他好友圖片時,則會立刻呼叫hidden方法,將先前的開啟正在計時的div關閉。

下面給出我的方法的JS程式碼:

//显示资料卡 
var beforeId; //定义全局变量 
function showInfoCard(thisObj,id){ 
this.hidden(beforeId); //立刻隐藏前一个选中弹出来的div 
beforeId = id; 
// alert(id); 
// var d = $(thisObj); 
// var pos = d.offset(); 
// var t = pos.top + d.height() - 5; // 弹出框的上边位置 
// var l = pos.left - d.width() - 600; // 弹出框的左边位置 
// $("#"+id).css({ "top": t, "left": l }).show(); 
// 

var objDiv = $("#"+id); 

$(objDiv).css("display","block"); 

$(objDiv).css("left", event.clientX-280); //弹出框的位置X值 

$(objDiv).css("top", event.clientY-10); //弹出框位置Y值 
} 
function hideInfoCard(id){ //隐藏div 
//延时3秒 
setTimeout('hidden('+id+')',3000); 
} 

function hidden(id){ 
$("#"+id).hide(); 
}

下面是HTML中的隱藏的div程式碼片段:

<div id="id" style="display:none; width:250px; height:150px; background-color:#D1EEEE;position:absolute;"></div>


在HTML中,需要呼叫showInfoCard和hideInfoCard方法,使用下列語句監聽滑鼠事件:

onmouseover="showInfoCard(this,'${friend.friendId}')" onmouseout="hideInfoCard('${friend.friendId}')" 


這些都是動態的程式碼片段,採用的時候需要引入jquery.js框架,當然也可以修改成純JS的。上面的完成了,AJAX取得信息,然後利用JS在上面div中插入HTML代碼即可完成顯示,最後來張初步的效果圖,挺醜的...

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn