基于JQuery的模擬蘋果桌面Dock效果(穩(wěn)定版)
更新時間:2012年10月15日 16:00:32 作者:
之所以將它命名為穩(wěn)定版,是因為之前已經(jīng)分享了一個初級版本的,之前的初級版中存在很多bug?,F(xiàn)在經(jīng)過反復(fù)琢磨、實驗,修復(fù)了之前版本存在的很多不足之處,就算鼠標快速的滑動依然表現(xiàn)的很穩(wěn)定
已經(jīng)迫不及待的想要將我的最新成果分享給大家了,其實代碼和之前的版本很相似。
首相是HTML頁面代碼:
<!DOCTYPE html>
<html lang="zh-cmn-Hans-CN">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>jQuery Dock</title>
<link type="text/css" rel="stylesheet" href="css/dock.css" />
<script type="text/javascript" src="js/jquery-1.8.0.js"></script>
<script type="text/javascript" src="js/dock.js"></script>
</head>
<body id="content">
<div id="topBody" align="center">
<div id="topMenu">
<a href="#"><img alt="Home" src="images/home.png" /></a>
<a href="#"><img alt="Music" src="images/music.png" /></a>
<a href="#"><img alt="Calendar" src="images/calendar.png" /></a>
<a href="#"><img alt="Email" src="images/email.png" /></a>
<a href="#"><img alt="Portfolio" src="images/portfolio.png" /></a>
<a href="#"><img alt="Video" src="images/video.png" /></a>
<a href="#"><img alt="Link" src="images/link.png" /></a>
<a href="#"><img alt="History" src="images/history.png" /></a>
<a href="#"><img alt="RSS" src="images/rss.png" /></a>
</div>
</div>
</body>
</html>
同樣加上相應(yīng)的CSS代碼:
#topMenu{
height:128px;
line-height:250px;
width: 630px;
background-image:url(../images/dock-bg1.png);
}
#topMenu img{
width: 50px;
height:50px;
border:none;
}
對應(yīng)的JS代碼如下:
$(function(){
$(this).mousemove(function(e){
var mouseY = parseInt(e.pageY);
if(mouseY<136 && mouseY>8){
var mouseX = parseInt(e.pageX);
$("#topMenu img").each(function(){
var obj = $(this);
var objWidth = obj.css("width");
//獲取圖片中心水平坐標
var objX = parseInt(obj.offset().left) + parseInt(objWidth.substr(0,objWidth.length-2))/2;
var x = Math.abs(objX-mouseX);
if(x<75){
obj.css("width",(128-((78*x*x)/(75*75)))+"px").css("height",(128-((78*x*x)/(75*75)))+"px");
}else{
obj.css("width","50px").css("height","50px");
}
});
}else{
$("#topMenu img").each(function(){
$(this).css("width","50px").css("height","50px");
});
}
});
});
相比于之前的版本最大的改變還是在JS上面,當(dāng)鼠標在頁面上移動時觸發(fā)mousemove事件,在mousemove方法中首先取得鼠標在頁面上的垂直坐標,判斷鼠標是否在可操作dock菜單的垂直范圍之內(nèi),如果鼠標不在這個范圍之內(nèi),就將所有圖標還原到初始狀態(tài);相反,如果鼠標在這個范圍之內(nèi),就繼續(xù)獲取鼠標在頁面上的水平坐標,并用mouseX來記錄。同時獲取圖片中心在頁面中的水平坐標,用objX來保存相應(yīng)的值,當(dāng)mouseX與objX之差的絕對值(用x來記錄)小于75時,就進入了當(dāng)前圖片的可操作范圍,dock效果就會觸發(fā),用y來表示當(dāng)鼠標移動時某一張圖片的width(為了簡單本次示例使用的圖標width和height相等的),本次示例用了方程 y=128-78*x2/752來表示鼠標的位置與圖片尺寸之間的關(guān)系,當(dāng) x 的大于75時就將對應(yīng)的圖片還原。
在本次示例的過程中發(fā)現(xiàn)了一個 ie 的一個小 bug ,當(dāng) <a> 標簽中間的內(nèi)容為 <img /> 時如果沒有給 img 的 border 的任何CSS樣式,則 ie 會給 img 加上藍色邊框,即使給 <a> 標簽加上 text-decoration: none; 的CSS樣式,img 仍然會被 ie 加上藍色邊框,當(dāng)給 img 添加 border:none; 之后煩人的藍色邊框就不見了。下圖是改進過后版本的演示圖,所有代碼僅供參考,謝謝閱讀。
首相是HTML頁面代碼:
復(fù)制代碼 代碼如下:
<!DOCTYPE html>
<html lang="zh-cmn-Hans-CN">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>jQuery Dock</title>
<link type="text/css" rel="stylesheet" href="css/dock.css" />
<script type="text/javascript" src="js/jquery-1.8.0.js"></script>
<script type="text/javascript" src="js/dock.js"></script>
</head>
<body id="content">
<div id="topBody" align="center">
<div id="topMenu">
<a href="#"><img alt="Home" src="images/home.png" /></a>
<a href="#"><img alt="Music" src="images/music.png" /></a>
<a href="#"><img alt="Calendar" src="images/calendar.png" /></a>
<a href="#"><img alt="Email" src="images/email.png" /></a>
<a href="#"><img alt="Portfolio" src="images/portfolio.png" /></a>
<a href="#"><img alt="Video" src="images/video.png" /></a>
<a href="#"><img alt="Link" src="images/link.png" /></a>
<a href="#"><img alt="History" src="images/history.png" /></a>
<a href="#"><img alt="RSS" src="images/rss.png" /></a>
</div>
</div>
</body>
</html>
同樣加上相應(yīng)的CSS代碼:
復(fù)制代碼 代碼如下:
#topMenu{
height:128px;
line-height:250px;
width: 630px;
background-image:url(../images/dock-bg1.png);
}
#topMenu img{
width: 50px;
height:50px;
border:none;
}
對應(yīng)的JS代碼如下:
復(fù)制代碼 代碼如下:
$(function(){
$(this).mousemove(function(e){
var mouseY = parseInt(e.pageY);
if(mouseY<136 && mouseY>8){
var mouseX = parseInt(e.pageX);
$("#topMenu img").each(function(){
var obj = $(this);
var objWidth = obj.css("width");
//獲取圖片中心水平坐標
var objX = parseInt(obj.offset().left) + parseInt(objWidth.substr(0,objWidth.length-2))/2;
var x = Math.abs(objX-mouseX);
if(x<75){
obj.css("width",(128-((78*x*x)/(75*75)))+"px").css("height",(128-((78*x*x)/(75*75)))+"px");
}else{
obj.css("width","50px").css("height","50px");
}
});
}else{
$("#topMenu img").each(function(){
$(this).css("width","50px").css("height","50px");
});
}
});
});
相比于之前的版本最大的改變還是在JS上面,當(dāng)鼠標在頁面上移動時觸發(fā)mousemove事件,在mousemove方法中首先取得鼠標在頁面上的垂直坐標,判斷鼠標是否在可操作dock菜單的垂直范圍之內(nèi),如果鼠標不在這個范圍之內(nèi),就將所有圖標還原到初始狀態(tài);相反,如果鼠標在這個范圍之內(nèi),就繼續(xù)獲取鼠標在頁面上的水平坐標,并用mouseX來記錄。同時獲取圖片中心在頁面中的水平坐標,用objX來保存相應(yīng)的值,當(dāng)mouseX與objX之差的絕對值(用x來記錄)小于75時,就進入了當(dāng)前圖片的可操作范圍,dock效果就會觸發(fā),用y來表示當(dāng)鼠標移動時某一張圖片的width(為了簡單本次示例使用的圖標width和height相等的),本次示例用了方程 y=128-78*x2/752來表示鼠標的位置與圖片尺寸之間的關(guān)系,當(dāng) x 的大于75時就將對應(yīng)的圖片還原。
在本次示例的過程中發(fā)現(xiàn)了一個 ie 的一個小 bug ,當(dāng) <a> 標簽中間的內(nèi)容為 <img /> 時如果沒有給 img 的 border 的任何CSS樣式,則 ie 會給 img 加上藍色邊框,即使給 <a> 標簽加上 text-decoration: none; 的CSS樣式,img 仍然會被 ie 加上藍色邊框,當(dāng)給 img 添加 border:none; 之后煩人的藍色邊框就不見了。下圖是改進過后版本的演示圖,所有代碼僅供參考,謝謝閱讀。

您可能感興趣的文章:
相關(guān)文章
js jquery獲取當(dāng)前元素的兄弟級 上一個 下一個元素
js獲取方法要比jq的方法麻煩的多,主要是因為FF瀏覽器,因為FF瀏覽器也會把換行當(dāng)作dom元素,下面跟著小編一起來學(xué)習(xí)js jquery獲取當(dāng)前元素的兄弟級 上一個 下一個元素的,需要的朋友一起來學(xué)習(xí)吧2015-09-09jQuery實現(xiàn)table中的tr上下移動并保持序號不變的實例代碼
下面小編就為大家?guī)硪黄猨Query實現(xiàn)table中的tr上下移動并保持序號不變的實例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07jQuery插件zTree實現(xiàn)更新根節(jié)點中第i個節(jié)點名稱的方法示例
這篇文章主要介紹了jQuery插件zTree實現(xiàn)更新根節(jié)點中第i個節(jié)點名稱的方法,結(jié)合實例形式分析了樹形插件zTree針對節(jié)點的更新操作相關(guān)技巧,需要的朋友可以參考下2017-03-03