JQuery使用及基礎原理解析相關筆記(一)

1.jquery

◆很強大,但是很臃腫,需要自己封裝一個jquery,要用到jqery中哪些方法,就把原來jquery中的方法拿出來。

◆jquery有兩大特點:鏈式編程、隱式迭代(遍歷)。


2.原生js的入口函數與jquery的入口函數

◆原生js的入口函數:

window.onload = function () {}

是頁面文檔和頁面資源都加載完畢之後開始執行函數裏面的代碼,

document.onready =function () {}

是頁面文檔加載完畢之後開始執行函數裏面的代碼(但是這個原生的js的入口函數是jquery腳本庫擴展出來的事件,只有在引入了jquery腳本庫的時候才能夠使用document.onready,沒有引入腳本庫的時候document對象是沒有這個事件的),document.onready 比 window.onload要快一點,因爲圖片資源還沒有顯示,document.onready裏的代碼就執行了,window.onload是頁面所有資源都加載完畢才執行的,window對象沒有onready。

◆jquery的入口函數:

$(document).ready(function () {});
$(function () {});
$(window).ready(function () {});
這三種方式都和document.onready一樣,都是頁面文檔加載完畢之後 就進入JQuery的入口函數開始執行函數裏面的代碼,

$(window).load(function () {});

這種方式和

window.οnlοad=function(){}

一樣,都是頁面文檔和頁面資源都加載完畢之後開始執行函數裏面的代碼。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JQuery的入口函數與原生js的入口函數</title>
    <script src="jquery-1.11.1.js"></script>
</head>
<body>
<script>


    //原生js的入口函數  :頁面文檔加載完畢之後,
    // 頁面需要加載的資源也加載完畢之後,就進入原生js的入口函數
    window.onload = function () {
        alert("原生js的入口函數  window.onload")

    }

    //window對象沒有onready事件  只有document對象有   ready要比load快
//    window.onready=function(){
//        alert("原生js的入口函數  window.onready")
//
//    }

    //原生js的入口函數  :頁面文檔加載完畢之後,就進入原生js的入口函數
    //效果與下面的$(document).ready(function(){});差不多   //但是這個document對象的事件是jquery腳本庫擴展出來的,
	 //所以在沒有引入jquery腳本庫時,
	 //document對象沒有這個事件
    document.onready = function () {
        alert("原生js的入口函數  document.onready")

    }

    //JQuery的入口函數 第一種方式 :頁面文檔加載完畢之後 就進入JQuery的入口函數
    $(document).ready(function () {
        alert("JQuery的入口函數 第一種方式 $(document).ready")
    });

    //JQuery的入口函數 第二種方式:頁面文檔加載完畢之後 就進入JQuery的入口函數
    $(function () {
        alert("JQuery的入口函數 第二種方式 $(function () ")
    });

    //JQuery的入口函數 第三種方式:頁面文檔加載完畢之後 就進入JQuery的入口函數
    $(window).ready(function () {
        alert("JQuery的入口函數 第三種方式 $(window).ready")

    })

    //這種jquery的入口函數 效果與window.onload差不多
    $(window).load(function () {
        alert("JQuery的入口函數 第四種方式 $(window).load")

    });

</script>
<img src="" alt="">
</body>
</html>


3.Query與$的區別:其實它們是一樣的,都是一個函數名,並且它們完全相等,jQuery===$。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>JQuery與$的區別(其實他們是一樣的)</title>
    <script src="jquery-1.11.1.js"></script>
    <script>


        console.log(console);
        console.log($);//$其實是一個函數名
        console.log(jQuery);//jQuery其實是一個函數名
        console.log($===jQuery);//他們是用一個函數
    </script>
</head>
<body>
</body>
</html>


4.jQuery中的dom對象與原生js中的dom對象的區別

◆jQuery的dom對象是對js的dom對象的封裝
◆jQuery無論是通過什麼方式獲取的dom對象都是僞數組,僞數組中裝的成員就是原生js的dom對象。
◆不光是將原生js的dom對象封裝到數組中,並且還給這個數組增加了很多功能方法,也就是給原來的js的dom對象穿上了一層帶有功能的皮膚,雖然原生的js的dom對象也可以自己封裝這些功能方法,但是兼容性沒有jQuery的那麼好。
★模擬jQuery對象操作css樣式的功能方法

 Object.prototype.css = function (json) {
        var cssArr = [];
        for (var key in json) {
            cssArr.push(key + ":" + json[key]);
        }
        this.style.cssText = cssArr.join(";");
    }
    box.css({width: "200px", height: "200px", "background-color": "#f00"});

★jquery與js操作樣式的方式

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>jquery與js操作樣式的方式</title>
    <script src="jquery-1.11.1.js"></script>
</head>
<body>
<div id="box1"></div>
<div id="box2"></div>


<script>
    var box1 = document.getElementById("box1");
    var box2 = $("#box2");
    //原生js一次性設置所有的樣式 可以使用 cssText屬性
    box1.style.cssText = "width:200px;height:200px;background-color:#0f0";
    //jquery一次性設置所有的樣式 可以使用css();
    box2.css({width: "200px", height: "200px", "background-color": "#f00"});

    //jquery獲取的dom對象是對js獲取的dom對象進行了封裝,
    // 給js的dom對象穿上了一層帶有功能的皮膚

    //    //自己給原生js封裝一下並且也穿上一層功能皮膚
    Object.prototype.css = function (json) {
        var cssArr = [];
        for (var key in json) {
            cssArr.push(key + ":" + json[key]);
        }
        this.style.cssText = cssArr.join(";");
    }
    box1.css({width: "200px", height: "200px", "background-color": "#f00"});

</script>
</body>
</html>

◆jQuery中的Dom對象與js中的Dom對象的區別和聯繫

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>jQuery中的Dom對象與js中的Dom對象的區別和聯繫</title>
    <script src="jquery-1.11.1.js"></script>
</head>
<body>
<div id="box" class="cbox"></div>
<script>
    // js和jquery通過id獲取dom對象\\

    var box = document.getElementById("box");
    var jbox = $("#box");
    //<div id="box" class="cbox"></div>
    console.log(box);
    //jQuery.fn.init [div#box.cbox, context: document, selector: "#box"]
    console.log(jbox);


    console.log("-----------------------------------");

    // js和jquery通過class獲取dom對象\\
    var cbox = document.getElementsByClassName('cbox');
    var jcbox = $(".cbox");
    //HTMLCollection [div#box.cbox, box: div#box.cbox]
    console.log(cbox);
    //jQuery.fn.init [div#box.cbox, prevObject: jQuery.fn.init(1), context: document, selector: ".cbox"]
    console.log(jcbox);


    console.log("-----------------------------------");

    // js和jquery通過tagName獲取dom對象\\
    var div = document.getElementsByTagName("div");
    var jdiv = $('div');
    //HTMLCollection [div#box.cbox, box: div#box.cbox]
    console.log(div);
    //jQuery.fn.init [div#box.cbox, prevObject: jQuery.fn.init(1), context: document, selector: "div"]
    console.log(jdiv);




    console.log("-----------------------------------");

    //js通過id獲取的是一個dom對象  而jquery通過id獲取的是個數組,
    //js通過tagName與class獲取的是一個數組  jquery通過tagName與class獲取的也是一個數組
    //通過結構可以看出,jquery獲取的dom對象是對js獲取的dom對象進行了封裝。

</script>
</body>
</html>


5.原生的js的dom對象可以和jQuery的dom對象相互轉換

◆js的dom對象轉換爲jQuery的dom對象:$(js的dom對象)或jQuery(js的dom對象)。

◆jQuery的dom對象轉換爲js的dom對象:jQuery的dom對象[index]或jQuery的dom對象.get(index),就可以獲取jQuery的dom對象的僞數組中的一個dom對象,但是如果get方法中不寫索引就可以獲取jQuery的dom對象的僞數組中的所有的dom對象,jQuery的dom對象.get()獲取一個正常的原生js的dom對象的數組,不再是僞裝數組。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>jQuery的dom對象與js的dom對象之間相互轉換</title>
    <script src="jquery-1.11.1.js"></script>
</head>
<body>
<div></div>
<div class="boxc"></div>
<div id="boxi"></div>
<div></div>
<div></div>
<script>

    //js的dom對象
    var boxtag = document.getElementsByTagName("div");
    var boxc = document.getElementsByClassName("boxc");
    var boxi = document.getElementById("boxi");

    //jquery的dom對象
    var jqboxtag = $("div");
    var jqboxc = $(".boxc");
    var jqboxi = $("#boxi");

    //使用jquery的dom對象 改變css樣式
    jqboxtag.css({width: 100, height: 100, border: "1px solid #0f0"});

    //將js 的dom對象 轉換爲jquery的dom對象
    boxi = $(boxi);
    //使用轉換爲jquery的dom對象 改變css樣式
//    boxi.css({"background-color": "#f00"});//可以傳json 設置多個屬性
    boxi.css("background-color", "#f00");//可以傳字符串 設置一個屬性

    //將jquery的dom對象 轉換爲js的dom對象
    jqboxc = jqboxc[0];
    jqboxc.style["background-color"] = "#ff0";

    console.log(jqboxtag);
    console.log(jqboxtag.get());
    //    再將jquery的dom對象 轉換爲js的dom對象
    jqboxi = jqboxi.get(0);//這個方法如果不傳參數 則會返回一個數組
    jqboxi.innerHTML = "將jquery的dom對象 轉換爲js的dom對象成功";

    //jquery的dom對象都是數組,將原生的js對象封裝到了一個數組中,
    // 所以你才能夠通過[]來獲取原生的js的dom對象,
    // get方法是給這個數組新增的,傳遞索引時就返回dom對象,
    // 不傳索引時就返回裝着dom對象的正常數組。

</script>
</body>
</html>


6.jQuery中的僞數組是怎麼實現的,清空原本數組中的原型(所有功能方法),添加自己新增的功能方法,添加索引爲字符串的成員context

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>jQuery對象是這樣的僞數組</title>
</head>
<body>
<script>
    //模擬jquery的dom對象的封裝 ,jquery的dom對象就是這樣的僞數組
    var arr = [];
    arr[0] = 0;
    arr[1] = 1;
    arr[2] = 2;
    arr[3] = 3;
    arr[4] = 4;
    arr["5"] = 5;

    //js的數組[]裏面不光是索引 還可以是字符串
    arr["context"] = document;

        //清空數組的原型  沒有數組的方法了
        arr["__proto__"] = null;

    console.log(arr);//打印僞數組

    //這樣只能遍歷索引爲數字的   或者索引爲字符串的數字的
    for (var i = 0; i < arr.length; i++) {
        console.log(i + "   " + arr[i]);
    }

    //這樣既可以遍歷索引爲數字的也可以遍歷索引爲字符串的
    for (var key in arr) {
        console.log(key + "  " + arr[key]);
    }

</script>
</body>
</html>


7.簡單使用jQuery:隔行變色、頁面開關燈

◆隔行變色

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用jQuery進行隔行變色</title>
    <script src="jquery-1.11.1.js"></script>

    <script>
        $(document).ready(function () {
            var liArr = $("li");
            //因爲jquery的dom對象是僞數組 所以可以直接使用for循環
            for (var i = 0; i < liArr.length; i++) {
                if (i % 2 == 0) {
                    liArr.get(i).style.backgroundColor = "#f00";
                } else {
                    liArr[i].style.backgroundColor = "#0f0";
                }
            }
        });
    </script>
</head>
<body>
<ul>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
    <li>使用jQuery進行隔行變色</li>
</ul>
</body>
</html>

◆頁面開關燈

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用jQuery進行頁面開關燈</title>
    <style type="text/css">
        img {
            display: block;
            margin: 100px auto;
        }
    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>

        $(document).ready(function () {
            var btns = document.getElementsByTagName("button");
            var body = $("body");

            $(btns[0]).click(function () {//開燈
                body[0].style.backgroundColor = "white";
            })
            $(btns[1]).click(function () {//關燈
                body.get(0).style.backgroundColor = "black";
            })
        });

    </script>
</head>
<body>
<button>開燈</button>
<button>關燈</button>
<img src="images/jQuery對象和DOM對象.png" width="500" alt="">
</body>
</html>

8.jQuery的基本選擇器:

◆無論什麼選擇器,返回的都是封裝着原生的dom對象的僞數組。

◆$(id選擇器),$(element選擇器),$(class選擇器),$(*通配符選擇器),$(選擇器1,選擇器2,選擇器3,選擇器4)....$(css選擇器),其實在css中使用的選擇器,都可以放到$()中作爲選擇器

$("li")
$(".li")
$("*")
$("li,.li,#li,*")
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>基本選擇器</title>
    <script src="jquery-1.11.1.js"></script>
</head>
<body>
<ul>
    <li></li>
    <li class="li"></li>
    <li id="li"></li>
    <li class="li"></li>
    <li></li>
</ul>
<script>
    //元素選擇器
    var element=$("li");
    element.css({width:"100px",height:"100px","margin-top":"5px","background-color":"#501"});

    //類選擇器
    var class1=$(".li");
    class1.css("background-color","#091");

    //id選擇器
    var id1=$("#li");
    id1.css({"border":"1px solid #009","background-color":"#ff0"});

    //*通配符選擇器
    var all0=$("*");

    //並集選擇器
    var bj=$("li,.li,#li,*");

</script>
</body>
</html>


9.jQuery的層級選擇器:

◆$(祖 子)後代選擇器,$(父>子)子代選擇器,$(前+緊接着的後)後兄弟選擇器,$(前~所有的後)後同輩選擇器,其實在css中使用的選擇器,都可以放到$()中作爲選擇器

$("ul li")
$("ul>li")
$("#prv+ol")
$("#prv~li")
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>層級選擇器</title>
    <script src="jquery-1.11.1.js"></script>
    <script>
        $(function () {
            //後代選擇器
            var li1 = $("ul li");
            li1.css({"background-color":"#0f0","margin":"5px"});

            //子代選擇器
            var li2 = $("ul>li");
            li2.css({"border":"1px solid #f00"});

            //後兄弟選擇器
            var next = $("#prv+ol");
            next.css("border","2px solid #00f");

            //後同輩選擇器
            var nextall = $("#prv~li");
            nextall.css("border","5px solid #000");
        });
    </script>
</head>
<body>
<ul>
    <li></li>
    <li></li>
    <li id="prv"></li>
    <ol>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ol>
    <li></li>
    <li></li>
</ul>
</body>
</html>


10.jQuery的基本過濾選擇器

◆在基本選擇器的基礎上進行過濾操作:如$("li:first");,找到所有li後直接找到第一個li。

:first過濾第一個、

:not(selector)過濾不包含selector的、

:even過濾索引爲偶數的、

:odd過濾索引爲奇數的、

:eq(index)過濾索引等於index的、

:gt(index)過濾索引大於index的、

:last過濾最後一個、

:lt(index)過濾索引小於index的、

:header過濾h1-h6、

:animated過濾正在執行動畫的、

:focus過濾已經獲取焦點。


11.jQuery的篩選選擇器

 ◆ 篩選過濾選擇器操作:如$("li").eq(0);和$("li:even").eq(0);,前者表示找到所有li後過濾第一個li,後者表示找到所有索引爲偶數的li後過濾第一個。

//    eq(index | -index) //等於索引的元素
//    first() //第一個元素
//    last() //最後一個元素
//    hasClass(class) //是否包含類
//    filter(expr | obj | ele | fn)
//    is(expr | obj | ele | fn)
//    map(callback)
//    has(expr | ele)
//    not(expr | ele | fn) 是否不包含
//    slice(start, [end])

    ◆篩選查找選擇器操作:如$("li").eq(0).next();或者$("li:first").next();,都是找到第一個li然後在此基礎上查找下一個。

//    children([expr]) //找子代
//    closest(e | o | e)1.7 *
//    find(e | o | e)//從jquery對象的後代中查找必須制定參數,如果不指定獲取不到元素
//    next([expr])//下一個
//    nextall([expr])//下面的全部
//    nextUntil([e | e][, f])
//    offsetParent() //帶有定位的父節點
//    parent([expr]) //父節點
//    parents([expr])
//    parentsUntil([e | e][, f])
//    prev([expr]) //上一個
//    prevall([expr]) //上面的全部
//    prevUntil([e | e][, f])
//    siblings([expr]) //所有兄弟 除了自己

 

12.使用JQuery的選擇器來DIY動畫效果:下拉菜單、隔行變色、高亮顯示戲曲牌、手風琴摺疊面板、服飾廣告

◆下拉菜單

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用jQuery的選擇器製作下拉菜單</title>
    <style type="text/css">

        * {
            margin: 0;
            padding: 0;
        }

        ul {
            list-style: none;
        }

        .wrap {
            width: 330px;
            height: 30px;
            margin: 100px auto 0;
            padding-left: 10px;
            background-image: url(images/bg.jpg);
        }

        .wrap li {
            background-image: url(images/libg.jpg);
        }

        .wrap > ul > li {
            float: left;
            margin-right: 10px;
            position: relative;
        }

        .wrap a {
            display: block;
            height: 30px;
            width: 100px;
            text-decoration: none;
            color: #000;
            line-height: 30px;
            text-align: center;
        }

        .wrap li ul {
            position: absolute;
            top: 30px;
            display: none;
        }

    </style>
    <script type="text/javascript" src="jquery-1.11.1.js"></script>
    <script>

        //需求:當移入到一級菜單時,顯示對應的二級菜單,移出時隱藏對應的二級菜單
        //思路:所有一級菜單的鼠標移入事件,
        // 然後show當前一級菜單下的ul,
        // 移出時hide當前一級菜單下的ul
        //步驟:
        //1.獲取事件源及相關元素對象
        //2.綁定事件
        //3.書寫事件驅動程序

        $(document).ready(function () {

            //1.獲取事件源及相關元素對象
            var wrap = $(".wrap");
            var liArr = wrap.children("ul").children("li");
//            console.log(wrap)
//            console.log(liArr)

            //2.綁定事件
            liArr.mouseenter(function () {
                $(this).children("ul").show();
            });
            liArr.mouseleave(function () {
                $(this).children("ul").hide();
            });


            //3.書寫事件驅動程序

        });


    </script>

</head>
<body>
<div class="wrap">
    <ul>
        <li>
            <a href="javascript:void(0);">一級菜單1</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">一級菜單2</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
        <li>
            <a href="javascript:void(0);">一級菜單3</a>
            <ul>
                <li><a href="javascript:void(0);">二級菜單1</a></li>
                <li><a href="javascript:void(0);">二級菜單2</a></li>
                <li><a href="javascript:void(0);">二級菜單3</a></li>
            </ul>
        </li>
    </ul>
</div>
</body>
</html>

◆隔行變色

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用jQuery的選擇器製作-隔行變色</title>
</head>
<body>
<ul>
    <li>使用jQuery的選擇器製作-隔行變色</li>
    <li>使用jQuery的選擇器製作-隔行變色</li>
    <li>使用jQuery的選擇器製作-隔行變色</li>
    <li>使用jQuery的選擇器製作-隔行變色</li>
    <li>使用jQuery的選擇器製作-隔行變色</li>
</ul>
<script src="jquery-1.11.1.js"></script>
<script>

    //需求:
    // 首先 讓ul中的li 索引爲偶數就變綠,索引爲奇數就變紅,
    // 然後讓鼠標移入時顏色變藍,移除就恢復原樣
    //思路:
    //使用:even和:odd基本過濾器來找到對應的li改變其顏色
    //設置li的鼠標移入事件和移出事件,並且設置一個計數器
    //鼠標移入時記錄顏色,鼠標移出時把記錄的顏色賦值回去
    //步驟:
    //獲取事件源及相關元素對象
    //綁定事件
    //書寫事件驅動程序

    //獲取事件源及相關元素對象
    var evenLi = $("li:even");//偶數索引的li
    var oddLi = $("li:odd");//奇數索引的li
    var allLi = $("li");//全部li

    //設置隔行變色
    evenLi.css("background", "#0f0");
    oddLi.css("background", "#f00");

    //綁定事件
    var color = "";
    allLi.mouseenter(function () {
        color = $(this).css("background");
        $(this).css("background", "#00f");
    });
    allLi.mouseleave(function () {
        $(this).css("background", color);
    });


    //書寫事件驅動程序


</script>
</body>
</html>

◆高亮顯示戲曲牌

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>使用jQuery的選擇器製作-高亮顯示戲曲牌</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
        }

        ul {
            list-style: none;
        }

        body {
            background: #000;
        }

        .wrap {
            margin: 100px auto 0;
            width: 630px;
            height: 394px;
            padding: 10px 0 0 10px;
            background: #000;
            overflow: hidden;
            border: 1px solid #fff;
        }

        .wrap li {
            float: left;
            margin: 0 10px 10px 0;

        }

        .wrap img {
            display: block;
            border: 0;
        }
    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>

        //防止圖片加載不出來
        $(window).load(function () {
            //需求:首先讓所有圖片透明度變爲0.4,當鼠標移入到某一張圖片上時透明度變爲1.0
            //思路:改變透明度而已,設置opacity屬性即可
            //步驟:
            //1.獲取事件源及相關元素對象
            //2.綁定事件
            //3.書寫事件驅動程序

            //1.獲取事件源及相關元素對象
            var liArr = $(".wrap>ul>li");
            liArr.css("opacity", "0.4");
            //2.綁定事件
            liArr.mouseenter(function () {
                $(this).css("opacity", "1.0");

            });
            liArr.mouseleave(function () {
                $(this).css("opacity", "0.4");

            });

            //3.書寫事件驅動程序


        });

    </script>
</head>
<body>
<div class="wrap">
    <ul>
        <li><a href="#"><img src="images/01.jpg" alt=""/></a></li>
        <li><a href="#"><img src="images/02.jpg" alt=""/></a></li>
        <li><a href="#"><img src="images/03.jpg" alt=""/></a></li>
        <li><a href="#"><img src="images/04.jpg" alt=""/></a></li>
        <li><a href="#"><img src="images/05.jpg" alt=""/></a></li>
        <li><a href="#"><img src="images/06.jpg" alt=""/></a></li>
    </ul>
</div>
</body>
</html>

◆手風琴摺疊面板

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>使用jQuery的選擇器製作-手風琴摺疊面板</title>
    <style type="text/css">
        * {
            padding: 0;
            margin: 0;
        }

        ul {
            list-style-type: none;
        }

        .parentWrap {
            width: 200px;
            text-align: center;

        }

        .menuGroup {
            border: 1px solid #999;
            background-color: #e0ecff;
        }

        .groupTitle {
            display: block;
            height: 20px;
            line-height: 20px;
            font-size: 16px;
            border-bottom: 1px solid #ccc;
            cursor: pointer;
        }

        .menuGroup > div {
            height: 200px;
            background-color: #fff;
            display: none;
        }

    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>

        $(function () {

            //需求:當點擊手風琴的某個面板的標題時,
            // 展開當前面板中的內容
            // 隱藏其它面板中的內容
            //思路:設置每一個標題的單擊事件
            //      當點擊時讓內容的顯示
            //      讓其它面板的內容隱藏
            //步驟:
            //1.獲取事件源及相關元素對象
            //2.綁定事件
            //3.書寫事件驅動程序

            //1.獲取事件源及相關元素對象
            var span = $(".parentWrap>.menuGroup>.groupTitle");

            //2.綁定事件
            span.click(function () {
                //鏈式書寫,顯示自己 隱藏其它
                $(this).next("div").show().parent("li").siblings("li").children("div").hide();
            });

            //3.書寫事件驅動程序


        });

    </script>
</head>
<body>
<ul class="parentWrap">
    <li class="menuGroup">
        <span class="groupTitle">標題1</span>
        <div>我是彈出來的div1</div>
    </li>
    <li class="menuGroup">
        <span class="groupTitle">標題2</span>
        <div>我是彈出來的div2</div>
    </li>
    <li class="menuGroup">
        <span class="groupTitle">標題3</span>
        <div>我是彈出來的div3</div>
    </li>
    <li class="menuGroup">
        <span class="groupTitle">標題4</span>
        <div>我是彈出來的div4</div>
    </li>
</ul>
</body>

◆服飾廣告

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>使用jQuery的選擇器製作-淘寶精品服飾廣告</title>
    <style type="text/css">
        * {
            margin: 0;
            padding: 0;
            font-size: 12px;
        }

        ul {
            list-style: none;
        }

        a {
            text-decoration: none;
        }

        .wrapper {
            width: 298px;
            height: 248px;
            margin: 100px auto 0;
            border: 1px solid pink;
            overflow: hidden;
        }

        #left, #center, #right {
            float: left;
        }

        #left li, #right li {
            background: url(images/lili.jpg) repeat-x;
        }

        #left li a, #right li a {
            display: block;
            width: 48px;
            height: 27px;
            border-bottom: 1px solid pink;
            line-height: 27px;
            text-align: center;
            color: black;
        }

        #left li a:hover, #right li a:hover {
            background-image: url(images/abg.gif);
        }

        #center {
            border-left: 1px solid pink;
            border-right: 1px solid pink;
        }
    </style>
    <script src="jquery-1.11.1.js"></script>
    <script>

        $(function () {

            //需求:當鼠標移入到對應的欄目時顯示對應的商品
            //思路:先給左邊的欄目設置鼠標移入事件  對應的li索引展示對應的商品
            //      再給右邊的欄目設置鼠標移入事件  在對應的索引上加9
            //步驟:
            //1.獲取事件源及相關元素對象
            //2.綁定事件
            //3.書寫事件驅動程序

            //1.獲取事件源及相關元素對象
            var liLeft = $("#left>li");
            var liRight = $("#right>li");
            var liCenter = $("#center>li");

            //2.綁定事件
            liLeft.mouseenter(function () {
                liCenter.eq($(this).index()).show().siblings().hide();
            });


            liRight.mouseenter(function () {
                console.log(liCenter.eq($(this).index() + 9));
                liCenter.eq($(this).index() + 9).show().siblings().hide();
            });

            //3.書寫事件驅動程序


        })

    </script>
</head>
<body>
<div class="wrapper">

    <ul id="left">
        <li><a href="#">女靴</a></li>
        <li><a href="#">雪地靴</a></li>
        <li><a href="#">冬裙</a></li>
        <li><a href="#">呢大衣</a></li>
        <li><a href="#">毛衣</a></li>
        <li><a href="#">棉服</a></li>
        <li><a href="#">女褲</a></li>
        <li><a href="#">羽絨服</a></li>
        <li><a href="#">牛仔褲</a></li>
    </ul>
    <ul id="center">
        <li><a href="#"><img src="images/女靴.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/雪地靴.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/冬裙.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/呢大衣.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/毛衣.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/棉服.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/女褲.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/羽絨服.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/牛仔褲.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/女包.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/男包.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/登山鞋.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/皮帶.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/圍巾.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/皮衣.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/男毛衣.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/男棉服.jpg" width="200" height="250"/></a></li>
        <li><a href="#"><img src="images/男靴.jpg" width="200" height="250"/></a></li>
    </ul>
    <ul id="right">
        <li><a href="#">女包</a></li>
        <li><a href="#">男包</a></li>
        <li><a href="#">登山鞋</a></li>
        <li><a href="#">皮帶</a></li>
        <li><a href="#">圍巾</a></li>
        <li><a href="#">皮衣</a></li>
        <li><a href="#">男毛衣</a></li>
        <li><a href="#">男棉服</a></li>
        <li><a href="#">男靴</a></li>
    </ul>

</div>
</body>
</html>


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章