国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

jQuery實現(xiàn)級聯(lián)菜單效果(仿淘寶首頁菜單動畫)

2024-05-06 16:03:57
字體:
供稿:網(wǎng)友
今天我們就帶大家體會一下級聯(lián)菜單的顯示,只是實現(xiàn)了簡單的效果,不過大都原理是一樣的

相信初學HTM+DIV+CSSl的同學們肯定也想做出淘寶網(wǎng)首頁的菜單動畫吧。今天我們就帶大家體會一下級聯(lián)菜單的顯示。小編我只是實現(xiàn)了簡單地效果,不過總體來說原理是一樣的哦,那么先讓大家看看效果圖吧。

那么要實現(xiàn)這個效果我們當然要使用到的是jQuery,那么我就開始講解怎么做的了,先上html和css的代碼

復制代碼 代碼如下:


<!DOCTYPE html>
<html>
<head>
<title>menu.html</title>

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=UTF-8">

<link type="text/css" href="../css/menu.css">
<script type="text/javascript" src="../js/jquery-1.10.2.js"></script>
<script type="text/javascript" src="../js/menu.js"></script>

</head>

<body>
<ul>
<li>
<div>
<span>電腦數(shù)碼類產(chǎn)品</span>
</div>
<ul>
<li><a href="#">筆記本</a>
<ul>
<li><a href="#">筆記本1</a></li>
<li><a href="#">筆記本1</a></li>
<li><a href="#">筆記本1</a></li>
<li><a href="#">筆記本1</a></li>
</ul>
</li>

<li><a href="#">移動硬盤</a>
<ul>
<li><a href="#">移動硬盤1</a></li>
<li><a href="#">移動硬盤1</a></li>
<li><a href="#">移動硬盤1</a></li>
<li><a href="#">移動硬盤1</a></li>

</ul>
</li>
<li><a href="#">電腦軟件</a>
<ul>
<li><a href="#">電腦軟件1</a></li>
<li><a href="#">電腦軟件1</a></li>
<li><a href="#">電腦軟件1</a></li>
<li><a href="#">電腦軟件1</a></li>

</ul>
</li>
<li><a href="#">數(shù)碼產(chǎn)品</a>
<ul>
<li><a href="#">數(shù)碼產(chǎn)品1</a></li>
<li><a href="#">數(shù)碼產(chǎn)品1</a></li>
<li><a href="#">數(shù)碼產(chǎn)品1</a></li>
<li><a href="#">數(shù)碼產(chǎn)品1</a></li>
</ul>
</li>

</ul>
</li>

</ul>
</body>
</html>


menu.css

復制代碼 代碼如下:


@CHARSET "UTF-8";

*{
margin: 0px;
padding: 0px;

}

ul,li{
list-style-type: none;

}

.menu{
width: 190px;
border: 1px red solid;
background-color: #fffdd2;
}

.optn{
width: 190px;
line-height: 28px;
border-top: 1px red dashed;

}


.content{
padding-top:10px;
clear: left;
}


a{
text-decoration: none;
color: #666;
padding: 10px;
}
.optnFocus{
background-color: #fff;
font-weight: bold;

}

div{
padding: 10px;
}

.tip{
width: 190px;
border: 2px red solid;
position: absolute;
background-color: #fff;
display: none;
}

.tip li{
line-height: 23px;
}


接下來就是主要的jquery代碼:menu.js

復制代碼 代碼如下:


$(function(){

var curY;//獲取所選想的TOP
var curH;//獲取所選的Height
var curW;//獲取所選的width
var objL;//獲取當前對象

//自定義函數(shù)用于獲取當前位置
function setInitValue(obj){
curY=obj.offset().top;
curH=obj.height();
curW=obj.width();
}

//設置當前所選項的鼠標滑動事件
$(".optn").mouseover(function(){
objL=$(this);//獲取當前對象
setInitValue(objL);
var allY=curY-curH +"px";

objL.addClass("optnFocus");
//獲取氣元素下的下一個ul
$(".tip",this).show().css({"top":allY,"left":curW});;

});
$(".optn").mouseout(function(){

$(this).removeClass("optnFocus");
$(".tip",this).hide();

});

//為了防止移到子菜單時子菜單不見,我們也要為子菜單設置鼠標事件

$(".tip").mouseover(function(){

$(this).show();
objL=$(this).prev("li");
setInitValue(objL);
objL.addClass("optnFocus");
});

$(".tip").mouseout(function(){
$(this).hide();
$(this).prev("li").removeClass("optnFocus");

});
});


注意要點:

1.由于我們用的是較高版本的jquery文件庫,所以有些方法是不支持的,例如獲取下一個元素的第一個子元素next(erp),在10.1中是不支持的,所以我換了一種方法$(chiled,select),表示在select的范圍進行元素的選擇

2.整個效果的實現(xiàn)我們還要為子選項框綁定鼠標事件,目的就是為了不在我們移動到子選項卡中,突然消失。

要實現(xiàn)好看的效果就需要加一些圖片和樣式,不過原理是一樣的哦
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 株洲市| 稷山县| 镇康县| 五莲县| 登封市| 凤山县| 雷波县| 饶河县| 宾阳县| 那坡县| 南岸区| 达孜县| 仁怀市| 榆林市| 昌宁县| 通辽市| 台湾省| 雷山县| 双城市| 麻城市| 葵青区| 顺昌县| 玉树县| 淮南市| 蒲江县| 鲁甸县| 福安市| 颍上县| 巩义市| 湖北省| 博客| 太仆寺旗| 青河县| 通城县| 南宫市| 西吉县| 菏泽市| 银川市| 银川市| 安康市| 望城县|