jQuery的介紹和選擇器詳解

来源:https://www.cnblogs.com/smyhvae/archive/2018/02/04/8414627.html
-Advertisement-
Play Games

本文最初發表於 "博客園" ,併在 "GitHub" 上持續更新 前端的系列文章 。歡迎在GitHub上關註我,一起入門和進階前端。 以下是正文。 jQuery 的介紹 引入 jQuery 的原因 在用 js 寫代碼時,會遇到一些問題: window.onload 事件有事件覆蓋的問題,因此只能寫一 ...


本文最初發表於博客園,併在GitHub上持續更新前端的系列文章。歡迎在GitHub上關註我,一起入門和進階前端。

以下是正文。

jQuery 的介紹

引入 jQuery 的原因

在用 js 寫代碼時,會遇到一些問題:

  • window.onload 事件有事件覆蓋的問題,因此只能寫一個事件。

  • 代碼容錯性差。

  • 瀏覽器相容性問題。

  • 書寫很繁瑣,代碼量多。

  • 代碼很亂,各個頁面到處都是。

  • 動畫效果很難實現。

如下圖所示:

jQuery的出現,可以解決以上問題。

什麼是 jQuery

jQuery 是 js 的一個庫,封裝了我們開發過程中常用的一些功能,方便我們調用,提高開發效率。

js庫是把我們常用的功能放到一個單獨的文件中,我們用的時候,直接引用到頁面里即可。

以下是jQuery的相關信息:

學習jQuery,主要是學什麼

初期,主要學習如何使用jQuery操作DOM,其實就是學習jQuery封裝好的那些功API。

這些API的共同特點是:幾乎全都是方法。所以,在使用jQuery的API時,都是方法調用,也就是說要加小括弧(),小括弧裡面是相應的參數,參數不同,功能不同。

jQuery初體驗

現在用原生 js 來寫下麵這一段代碼:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <style>
        div {
            height: 100px;
            background-color: pink;
            margin: 10px;
            display: none;
        }
    </style>

    <script>
        //原生js
        window.onload = function () {
            var btn = document.getElementsByTagName("button")[0];
            var divArr = document.getElementsByTagName("div");

            btn.onclick = function () {
                for (var i = 0; i < divArr.length; i++) {
                    divArr[i].style.display = "block";
                    divArr[i].innerHTML = "生命壹號";
                }
            }
        }
    </script>
</head>
<body>

<button>顯示五個div盒子和設置內容</button>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>

</body>
</html>

如果用 jQuery 來寫,保持其他的代碼不變,<script>部分的代碼修改為:(需要提前引入 )

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

        //jquery版
        $(document).ready(function () {
            //獲取元素
            var jQbtn = $("button");//根據標簽名獲取元素
            var jQdiv = $("div");//根據標簽名獲取元素
            //綁定事件
            jQbtn.click(function () {
                jQdiv.show(1000);//顯示盒子。
                jQdiv.html("tomorrow!");//設置內容
                //上面的兩行可以寫成鏈式編程:jQdiv.show(3000).html(1111);

            });//事件是通過方法綁定的。

        });
    </script>

jQuery 的兩大特點

  • 鏈式編程:比如.show().html()可以連寫成.show().html()

  • 隱式迭代:隱式 對應的是 顯式。隱式迭代的意思是:在方法的內部進行迴圈遍歷,而不用我們自己再進行迴圈,簡化我們的操作,方便我們調用。

jQuery 的使用

使用 jQuery 的基本步驟

(1)引包

(2)入口函數

(3)功能實現代碼(事件處理)

如下圖所示:

主要,導包的代碼一定要放在js代碼的最上面。

jQuery 的版本

jQuery 有兩個大版本:

  • 1.x版本:最新版為 v1.11.3。

  • 2.x版本:最新版為 v2.1.4(不再支持IE6、7、8)。

  • 3.x版本。

我們以 v1.11.1版本為例,下載下來後發現,裡面有兩個文件:

它們的區別是:

  • 第一個是未壓縮版,第二個是壓縮版。

  • 平時開發過程中,可以使用任意一個版本;但是,項目上線的時候,推薦使用壓縮版。

jQuery 的入口函數和 $ 符號

入口函數(重要)

原生 js 的入口函數指的是:window.onload = function() {}; 如下:

        //原生 js 的入口函數。頁面上所有內容載入完畢,才執行。
        //不僅要等文本載入完畢,而且要等圖片也要載入完畢,才執行函數。
       window.onload = function () {
           alert(1);
       }

而 jQuery的入口函數,有以下幾種寫法:

寫法一:

       //1.文檔載入完畢,圖片不載入的時候,就可以執行這個函數。
       $(document).ready(function () {
           alert(1);
       })

寫法二:(寫法一的簡潔版)

       //2.文檔載入完畢,圖片不載入的時候,就可以執行這個函數。
       $(function () {
           alert(1);
       });

寫法三:

       //3.文檔載入完畢,圖片也載入完畢的時候,在執行這個函數。
       $(window).ready(function () {
           alert(1);
       })

jQuery入口函數與js入口函數的區別

區別一:書寫個數不同:

  • Js 的入口函數只能出現一次,出現多次會存在事件覆蓋的問題。

  • jQuery 的入口函數,可以出現任意多次,並不存在事件覆蓋問題。

區別二:執行時機不同:

  • Js的入口函數是在所有的文件資源載入完成後,才執行。這些文件資源包括:頁面文檔、外部的js文件、外部的css文件、圖片等。

  • jQuery的入口函數,是在文檔載入完成後,就執行。文檔載入完成指的是:DOM樹載入完成後,就可以操作DOM了,不用等到所有的外部資源都載入完成。

文檔載入的順序:從上往下,邊解析邊執行。

jQuery的$符號

jQuery 使用 $ 符號原因:書寫簡潔、相對於其他字元與眾不同、容易被記住。

jQuery占用了我們兩個變數:$ 和 jQuery。當我們在代碼中列印它們倆的時候:

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

        console.log($);
        console.log(jQuery);
        console.log($===jQuery);


    </script>

列印結果如下:

從列印結果可以看出,$ 代表的就是 jQuery。

那怎麼理解jQuery裡面的 $ 符號呢?

$ 實際上表示的是一個函數名 如下:

    $(); // 調用上面我們自定義的函數$

    $(document).ready(function(){}); // 調用入口函數

    $(function(){}); // 調用入口函數

    $(“#btnShow”) // 獲取id屬性為btnShow的元素

    $(“div”) // 獲取所有的div標簽元素

如上方所示,jQuery 裡面的 $ 函數,根據傳入參數的不同,進行不同的調用,實現不同的功能。返回的是jQuery對象。

jQuery這個js庫,除了$ 之外,還提供了另外一個函數:jQuery。jQuery函數跟 $ 函數的關係:jQuery === $

js中的DOM對象 和 jQuery對象 比較(重點,難點)

二者的區別

通過 jQuery 獲取的元素是一個數組,數組中包含著原生JS中的DOM對象。舉例:

針對下麵這樣一個div結構:

<div></div>
<div class="box"></div>
<div id="box"></div>
<div class="box"></div>
<div></div>

通過原生 js 獲取這些元素節點的方式是:

    var myBox = document.getElementById("box");           //通過 id 獲取單個元素
    var boxArr = document.getElementsByClassName("box");  //通過 class 獲取的是數組
    var divArr = document.getElementsByTagName("div");    //通過標簽獲取的是數組

通過 jQuery 獲取這些元素節點的方式是:(獲取的都是數組)

    //獲取的是數組,裡面包含著原生 JS 中的DOM對象。
    var jqBox1 = $("#box");
    var jqBox2 = $(".box");
    var jqBox3 = $("div");

我們列印出來看看:

上圖顯示,由於JQuery 自帶了 css()方法,我們還可以直接在代碼中給 div 設置 css 屬性。

總結:jQuery 就是把 DOM 對象重新包裝了一下,讓其具有了 jQuery 方法。

二者的相互轉換

1、 DOM 對象 轉為 jQuery對象

    $(js對象);

舉例:(拿上一段的代碼舉例)

    //轉換。
    jqBox1 = $(myBox);
    jqBox2 = $(boxArr);
    jqBox3 = $(divArr);

DOM 對象轉換成了 jquery 對象之後,皮上面的功能可以直接調用。

2、jQuery對象 轉為 DOM 對象

    jquery對象[index];      //方式1(推薦)

    jquery對象.get(index);  //方式2

jQuery對象轉換成了 DOM 對象之後,可以直接調用 DOM 提供的一些功能。如:

    //jquery對象轉換成 DOM 對象之後
    jqBox3[0].style.backgroundColor = "black";
    jqBox3.get(4).style.backgroundColor = "pink";

總結:如果想要用哪種方式設置屬性或方法,必須轉換成該類型。

舉例:隔行變色

代碼如下:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="jquery-1.11.1.js"></script>
    <script>
        //入口函數
        jQuery(function () {
            var jqLi = $("li");
            for (var i = 0; i < jqLi.length; i++) {
                if (i % 2 === 0) {
                    //jquery對象,轉換成了js對象
                    jqLi[i].style.backgroundColor = "pink";
                } else {
                    jqLi[i].style.backgroundColor = "yellow";
                }
            }
        });
    </script>
</head>
<body>
<ul>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
    <li>生命壹號,永不止步</li>
</ul>
</body>
</html>

效果如下:

jQuery 選擇器

我們以前在CSS中學習的選擇器有:

今天來學習一下jQuery 選擇器。

jQuery選擇器是jQuery強大的體現,它提供了一組方法,讓我們更加方便的獲取到頁面中的元素。

1、jQuery 的基本選擇器

解釋如下:

舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="jquery-1.11.1.js"></script>
    <script>
        //入口函數
        jQuery(document).ready(function () {

            //三種方式獲取jquery對象
            var jqBox1 = $("#box");
            var jqBox2 = $(".box");
            var jqBox3 = $("div");

            //操作標簽選擇器
            jqBox3.css("width", 100);
            jqBox3.css("height", 100);
            jqBox3.css("margin", 10);
            jqBox3.css("background", "pink");

            //操作類選擇器(隱式迭代,不用一個一個設置)
            jqBox2.css("background", "red");

            //操作id選擇器
            jqBox1.css("background", "yellow");

        });
    </script>
</head>
<body>

<div></div>
<div class="box"></div>
<div id="box"></div>
<div class="box"></div>
<div></div>

</body>
</html>

效果如下:

2、層級選擇器

解釋如下:

舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="jquery-1.11.1.js"></script>
    <script>
        $(function () {
            //獲取ul中的li設置為粉色
            //後代:兒孫重孫曾孫玄孫....
            var jqLi = $("ul li");
            jqLi.css("margin", 5);
            jqLi.css("background", "pink");

            //子代:親兒子
            var jqOtherLi = $("ul>li");
            jqOtherLi.css("background", "red");
        });
    </script>
</head>
<body>
<ul>
    <li>111</li>
    <li>222</li>
    <li>333</li>
    <ol>
        <li>aaa</li>
        <li>bbb</li>
        <li>ccc</li>
    </ol>
</ul>
</body>
</html>

效果:

3、基本過濾選擇器

解釋:

舉例:

    <script src="jquery-1.11.1.js"></script>
    <script>
        $(document).ready(function () {

            // :odd
            $("li:odd").css("background", "red");

            // :even
            $("li:even").css("background", "green");

            // :eq(index)
            $("ul li:eq(3)").css("font-size", "30px");  //設置第四個li的字體

            // :lt(index)
            $("li:lt(6)").css("font-size", "30px");

            // :gt(index)
            $(".ulList1 li:gt(7)").css("font-size", "40px");

            // :first
            $(".ulList li:first").css("font-size", "40px");

            // :last
            $("li:last").css("font-size", "40px");
        });
    </script>

4、屬性選擇器

5、篩選選擇器

舉例:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title></title>
    <script src="jquery-1.11.1.js"></script>
    <script>
        jQuery(function () {
            var jqul = $("ul");

            //find(selector); 從jquery對象的後代中查找
            //必須制定參數,如果不指定獲取不到元素。length === 0
            jqul.find("li").css("background", "pink");
            console.log(jqul.find());

            //chidlren(selector); 從jquery對象的子代中查找
            //不寫參數代表獲取所有子元素。
            jqul.children("li").css("background", "green");

            //eq(索引值); 從jquery對象的子代中查找該索引值的元素
            //要寫該數組中的第幾個。
            jqul.children().eq(0).css("background", "red");

            //next(); 該元素的下一個兄弟元素
            jqul.children().eq(0).next().css("background", "yellow");

            //siblings(selector); 該元素的所有兄弟元素
            jqul.children().eq(0).next().siblings().css("border", "1px solid blue");

            //parent(); 該元素的父元素(和定位沒有關係)
            console.log(jqul.children().eq(0).parent());
        });
    </script>
</head>
<body>

<ul>
    <li>生命壹號,永不止步</li>
    <li class="box">生命壹號,永不止步</li>
    <span>生命壹號,永不止步</span>
    <li class="box">生命壹號,永不止步</li>
    <i>生命壹號,永不止步</i>
    <li>生命壹號,永不止步</li>
    <a id="box" href="#">生命壹號,永不止步</a>
    <ol>
        <li>我是ol中的li</li>
        <li>我是ol中的li</li>
        <li>我是ol中的li</li>
        <li>我是ol中的li</li>
    </ol>
</ul>

</body>
</html>

效果:

我的公眾號

想學習代碼之外的軟技能?不妨關註我的微信公眾號:生命團隊(id:vitateam)。

掃一掃,你將發現另一個全新的世界,而這將是一場美麗的意外:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. 什麼是資料庫? 資料庫(Database)是按照數據結構來組織、存儲和管理數據的建立在電腦存儲設備上的倉庫。 簡單來說是本身可視為電子化的文件櫃——存儲電子文件的處所,用戶可以對文件中的數據進行新增、截取、更新、刪除等操作。 嚴格來說,資料庫是長期儲存在電腦內、有組織的、可共用的數據集合。 ...
  • 1、按條件篩選,然後替換 select * from phome_ecms_tv where playurl like '%關鍵詞%';update phome_ecms_tv set myorder=REPLACE(myorder,'99','444') 2、刪除含某關鍵詞的內容 delete f ...
  • layout: post title: 2018 01 05 醫葯行業的IT革命探討 key: 20180105 tags: IT AI 醫療 modify_date: 2018 01 05 醫葯行業的IT革命探討 說明: 本文發佈於: "gitee" , "github" , "博客園" 轉載和引 ...
  • 一,模糊測試,是指通過反覆向待測應用發送畸形的數據,對應用進行動態測試的過程。 二,模糊測試,也稱動態分析,是一種構造非法輸入並將其提供給應用,以期讓應用暴露出某些安全問題的藝術和科學。 參考資料:《黑客攻防技術寶典-iOS實戰篇》 ...
  • 接著之前的那個從圖庫選擇圖片,設置到ImageView中去,但是,我發現了一個問題,就是再次進入的時候ImageView是恢復到了預設狀態,搜索了資料許久之後,終於是發現瞭解決方法,使用SharePreference儲存數據即可 貼上代碼 使用 在準備為ImageView設置圖片之前,將圖片路徑給保 ...
  • 準備工作: 1.兩張不同顏色的小圓點圖片,可以去阿裡巴巴矢量圖網站搜索 我把我使用的圖片貼出來 2.一個簡單的Viewpager的實現 下麵是簡單的Viewpager實現步驟: 1.佈局文件使用Viewpager 2.定義一個適配器類使其繼承PagerAdapter,覆寫其中的四個方法,分別是get ...
  • 我悟出權力本來就是不講理的——蟑螂就是海米;也悟出要造反,內心必須強大到足以承受任何後果才行。 ——北島《城門開》 本文為讀 lodash 源碼的第十篇,後續文章會更新到這個倉庫中,歡迎 star: "pocket lodash" gitbook也會同步倉庫的更新,gitbook地址: "pocke ...
  • css框模型 (一)內邊距 padding 內邊距即邊框和內容之間的空白區域h1 {padding: 10px 0.25em 2ex 20%;}四個值這種則分別是按照上,右,下,左的順序設置內邊距 單邊內邊距屬性padding-toppadding-rightpadding-bottompaddin ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...