jQuery的基本使用

jQuery是什么苍柏?能干什么?

  • jQuery是一款開(kāi)源免費(fèi)的JS 框架荚恶,對(duì)JS進(jìn)一步封裝
  • 沒(méi)有改進(jìn)語(yǔ)法撩穿,只是讓我們開(kāi)發(fā)者,在操作頁(yè)面元素谒撼、給頁(yè)面元素綁定事件食寡、發(fā)送AJAX請(qǐng)求等方面,代碼可以寫(xiě)得更簡(jiǎn)潔一些

jQuery版本介紹

  • jQuery1.x:經(jīng)典版本廓潜,兼容 IE6抵皱、7、8辩蛋。
  • jQuery2.0:改進(jìn)版本呻畸,后續(xù)版本將不再支持 IE6、7堪澎、8瀏覽器

jQuery的基本使用

  • jQuery對(duì)象與Dom對(duì)象之間的轉(zhuǎn)換
    <button id="btn">按鈕</button>
    
    // $與jQuery變量作用一致
    console.log($ === jQuery);//true
    
    // Dom對(duì)象
    let btn = document.getElementById("btn");
    console.log(btn);
    
    // jQuery對(duì)象
    let $btn = $("#btn");
    console.log($btn);
    
    // Dom對(duì)象轉(zhuǎn)換為jQuery對(duì)象
    console.log($(btn));
    
    // jQuery對(duì)象轉(zhuǎn)換為Dom對(duì)象
    console.log($btn.get(0));
    
  • jQuery的常用方法
    <h1 id="h1">做人<i>要低調(diào)</i></h1>
    
    <input type="text" id="username" value="wolfcode"/><br/><br/>
    <div>
        jQuery 常用方法:<br/>
        jQuery對(duì)象.size(); // 獲取 jQuery 中包含元素的個(gè)數(shù)<br/>
        jQuery對(duì)象.val(); // 操作元素的 value 屬性<br/>
        jQuery對(duì)象.html(); // 操作元素內(nèi)的 HTML 代碼<br/>
        jQuery對(duì)象.text(); // 操作元素內(nèi)的文本擂错,忽略 HTML 標(biāo)簽<br/>
        jQuery對(duì)象.css(); // 操作元素的 style 屬性
    </div>
    
    <hr/>
    
    <div>
        <p>
            問(wèn)題 1:獲取 jQuery 中包含 DOM 的個(gè)數(shù)味滞,比如獲取頁(yè)面上 p 元素的個(gè)數(shù)
        </p>
        <p>
            問(wèn)題 2:獲取 id 為 username 元素的 value 屬性值
        </p>
        <p>
            問(wèn)題 3:設(shè)置 id 為 username 元素的 value 屬性值為"叩丁狼教育"
        </p>
        <p>
            問(wèn)題 4:對(duì)比 h1 元素的內(nèi)容和純文本的區(qū)別
        </p>
        <p>
            問(wèn)題 5:把 h1 元素內(nèi)容的顏色改為黃色
        </p>
    </div>
    
    //問(wèn)題 1:獲取 jQuery 中包含 DOM 的個(gè)數(shù)樱蛤,比如獲取頁(yè)面上 p 元素的個(gè)數(shù)
    console.log($("p").size());
    
    //問(wèn)題 2:獲取 id 為 username 元素的 value 屬性值
    console.log($("#username").val());
    
    //問(wèn)題 3:設(shè)置 id 為 username 元素的 value 屬性值為"禹王穆好帥"
    $("#username").val("禹王穆好帥");
    
    //問(wèn)題 4:對(duì)比 h1 元素的內(nèi)容和純文本的區(qū)別
    console.log($("h1").html());
    console.log($("h1").text());
    
    //問(wèn)題 5:把 h1 元素內(nèi)容的顏色改為黃色
    $("#h1").css("color", "yellow");
    
  • jQuery的常用選擇器
    <div id="msg">使用 ID 選擇器獲取當(dāng)前 DIV元素</div>
    <ul>
        <li>item1</li>
        <li>item2</li>
        <li>item3</li>
        <li>item4</li>
    </ul>
    <ul id="myul">
        <li>item1</li>
        <li class="selected">item2</li>
        <li>item3</li>
        <li class="selected">item4</li>
    </ul>
    <hr/>
    <div>
        <p>
            問(wèn)題 1:獲取 id 為 msg 的元素的內(nèi)容
        </p>
        <p>
            問(wèn)題 2:獲取所有的 li 元素并打印數(shù)量
        </p>
        <p>
            問(wèn)題 3:獲取所有 class 為 selected 的元素,字體顏色改為 red
        </p>
    </div>
    
    // 問(wèn)題 1:獲取 id 為 msg 的元素的內(nèi)容
    console.log($("#msg").text());
    
    // 問(wèn)題 2:獲取所有的 li 元素并打印數(shù)量
    console.log($("li").size());
    
    // 問(wèn)題 3:獲取所有 class 為 selected 的元素剑鞍,字體顏色改為 red
    $(".selected").css("color", "red");
    
  • jQuery的層次選擇器
    <ul id="myul">
        <li>item1</li>
        <li>item2</li>
        <li>item3</li>
        <li>
            <ul>
                <li>item1</li>
                <li>item2</li>
                <li>item3</li>
                <li>item4</li>
            </ul>
        </li>
    </ul>
    <label>LABEL1</label>
    <input type="text" value="text1"/>
    <input type="text" value="text2"/>
    <br/>
    <label>LABEL2</label>
    <input type="text" value="text3"/>
    <input type="text" value="text4"/>
    <br/>
    <label>
        LABEL3
        <input type="text" value="text5"/>
        <input type="text" value="text6"/>
    </label>
    <hr/>
    <div>
        <p>
            問(wèn)題 1:獲取所有 ul 下的所有 li 元素昨凡,并打印分析結(jié)果
        </p>
        <p>
            問(wèn)題 2:獲取 id 為 myul 下的所有子 li 元素,并打印分析結(jié)果
        </p>
        <p>
            問(wèn)題 3:獲取所有 label 元素后的 input 元素蚁署,并打印分析結(jié)果
        </p>
        <p>
            問(wèn)題 4:獲取緊跟著 label 元素后的 input 元素便脊,并打印分析結(jié)果
        </p>
    </div>
    
    // 問(wèn)題 1:獲取所有 ul 下的所有 li 元素,并打印分析結(jié)果
    console.log($("ul li"));
    
    // 問(wèn)題 2:獲取 id 為 myul 下的所有子 li 元素光戈,并打印分析結(jié)果
    console.log($("#myul > li"));
    
    // 問(wèn)題 3:獲取所有 label 元素后的 input 元素哪痰,并打印分析結(jié)果
    console.log($("label ~ input"));
    
    // 問(wèn)題 4:獲取緊跟著 label 元素后的 input 元素遂赠,并打印分析結(jié)果
    console.log($("label + input"));
    
  • jQuery的過(guò)濾選擇器
    <input type="hidden" name="id" value="1">
    <select>
        <option value="1">Flowers</option>
        <option value="2" selected>Gardens</option>
        <option value="3">Trees</option>
    </select>
    <hr/>
    <div>
        <p>
            問(wèn)題 1:獲取隱藏 input 的 value 屬性值, 不能使用根據(jù)元素名, 也不能通過(guò)給元素加
            id 屬性,再通過(guò) id 選擇器找
        </p>
        <p>
            問(wèn)題 2:獲取選中的 option
        </p>
    </div>
    
    // 問(wèn)題 1:獲取隱藏 input 的 value 屬性值, 不能使用根據(jù)元素名, 也不能通過(guò)給元素加id 屬性晌杰,再通過(guò) id 選擇器找
    console.log($("input[type=hidden]").val());
    
    // 問(wèn)題 2:獲取選中的 option
    console.log($("option:selected").text());
    
  • jQuery事件綁定
    <button id="btn1">btn1</button>
    
    $("#btn1").click(function () {
        // this是Dom對(duì)象
        console.log(this);
    
        // 轉(zhuǎn)換為jQuery對(duì)象
        console.log($(this));
    });
    
  • jQueryDOM操作
    <span style="background-color : blue;color: red;" id="span">SPAN</span>
    <div id="div1" style="background-color: gray;">DIV1</div>
    <div id="div2" style="background-color: green;">DIV2</div>
    
    <ul id="ul">
        <li>item1</li>
        <li>item2</li>
        <li>item3</li>
        <li>item4</li>
        <li>item5</li>
    </ul>
    
    <input id="btn" type="button" value="刪除我"/>
    
    <form>
        <fieldset>
            <legend>內(nèi)部插入節(jié)點(diǎn)(插入子節(jié)點(diǎn))</legend>
            <input type="button" value="append" id="append"/>
        </fieldset>
    </form>
    
    <form>
        <fieldset>
            <legend>外部插入節(jié)點(diǎn)(插入兄弟節(jié)點(diǎn))</legend>
            <input type="button" value="after" id="after"/>
        </fieldset>
    </form>
    
    <form>
        <fieldset>
            <legend>刪除節(jié)點(diǎn)</legend>
            <input type="button" value="刪除所有子節(jié)點(diǎn)" id="empty"/>
            <input type="button" value="刪除節(jié)點(diǎn)" id="remove"/>
            <input type="button" value="恢復(fù)節(jié)點(diǎn)" id="resume"/>
        </fieldset>
    </form>
    
    //父親加小兒子
    $("#append").click(function () {
        $("#div1").append($("#span"));
    });
    
    //哥哥加弟弟
    $("#after").click(function () {
        $("#div2").after($("#div1"));
    });
    
    //清空所有節(jié)點(diǎn)
    $("#empty").click(function () {
        $("#ul").empty();
    });
    
    //刪除自己 detach
    $("#btn").click(function () {
        console.log("我被刪除了...");
    });
    
    let $btn;
    //刪除節(jié)點(diǎn)
    $("#remove").click(function () {
        //$btn = $("#btn").remove();
        $btn = $("#btn").detach();
    });
    
    //恢復(fù)節(jié)點(diǎn)
    $("#resume").click(function () {
        $("#ul").after($btn);
    });
    
  • jQuery屬性操作
    .other {
        background-color: orange;
        font-size: 20px;
    }
    .myBtn{
        background-color: red;
    }
    
    <input id="btn" type="button" value="點(diǎn)我"/>
    <form>
        <fieldset>
            <legend>屬性操作</legend>
            <input type="button" value="獲取屬性值" id="getAttr"/>
            <input type="button" value="設(shè)置屬性值" id="setAttr"/>
        </fieldset>
    </form>
    <form>
        <fieldset>
            <legend>CSS 操作</legend>
            <input type="button" value="添加CSS" id="addClass"/>
            <input type="button" value="刪除CSS" id="removeClass"/>
            <input type="button" value="輪換CSS" id="toggleClass"/>
            <input type="button" value="判斷CSS" id="hasClass"/>
        </fieldset>
    </form>
    <input type="checkbox" value="1" checked name="gender" id="gender" dataoption='{"name" : "蔣干"}' style="color: red; background: aqua" class="myBtn other" > 男
    
    // 獲取屬性值
    $("[id=getAttr]").click(function () {
        console.log($("legend").val());
    });
    
    // 設(shè)置屬性值
    $("[id=setAttr]").click(function () {
        $("legend").val("禹王穆專(zhuān)屬");
    });
    
    // 添加CSS
    $("#addClass").click(function () {
        $("legend").addClass("other");
    });
    
    // 刪除CSS
    $("#removeClass").click(function () {
        $("legend").removeClass("other");
    });
    
    // 輪換CSS
    $("#toggleClass").click(function () {
        $("legend").toggleClass("myBtn");
    });
    
    // 判斷CSS
    $("#hasClass").click(function () {
        console.log($("legend").hasClass("myBtn"));
    });
    
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末跷睦,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子肋演,更是在濱河造成了極大的恐慌抑诸,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件爹殊,死亡現(xiàn)場(chǎng)離奇詭異蜕乡,居然都是意外死亡馋劈,警方通過(guò)查閱死者的電腦和手機(jī)草娜,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)萝招,“玉大人绒瘦,你說(shuō)我怎么就攤上這事称簿。” “怎么了惰帽?”我有些...
    開(kāi)封第一講書(shū)人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵憨降,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我该酗,道長(zhǎng)授药,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任呜魄,我火速辦了婚禮悔叽,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘爵嗅。我一直安慰自己娇澎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布睹晒。 她就那樣靜靜地躺著趟庄,像睡著了一般。 火紅的嫁衣襯著肌膚如雪伪很。 梳的紋絲不亂的頭發(fā)上戚啥,一...
    開(kāi)封第一講書(shū)人閱讀 49,784評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音锉试,去河邊找鬼猫十。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拖云。 我是一名探鬼主播贷笛,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼宙项!你這毒婦竟也來(lái)了昨忆?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤杉允,失蹤者是張志新(化名)和其女友劉穎邑贴,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體叔磷,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡拢驾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了改基。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片繁疤。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖秕狰,靈堂內(nèi)的尸體忽然破棺而出稠腊,到底是詐尸還是另有隱情,我是刑警寧澤鸣哀,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布架忌,位于F島的核電站,受9級(jí)特大地震影響我衬,放射性物質(zhì)發(fā)生泄漏叹放。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一挠羔、第九天 我趴在偏房一處隱蔽的房頂上張望井仰。 院中可真熱鬧,春花似錦破加、人聲如沸俱恶。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)合是。三九已至,卻和暖如春尿背,著一層夾襖步出監(jiān)牢的瞬間端仰,已是汗流浹背捶惜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來(lái)泰國(guó)打工田藐, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓汽久,卻偏偏與公主長(zhǎng)得像鹤竭,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子景醇,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容