JQ操作DOM


回顧一下修改DOM的CSS、文本、設置HTML有多么麻煩,而且有的瀏覽器只有innerHTML,有的瀏覽器支持innerText,有了jQuery對象,不需要考慮瀏覽器差異了,全部統一操作!

修改Text和HTML

jQuery對象的text()html()方法分別獲取節點的文本原始HTML文本,例如,如下的HTML結構:

<!-- HTML結構 --> <ul id="test-ul"> <li class="js">JavaScript</li> <li name="book">Java &amp; JavaScript</li> </ul> 

分別獲取文本和HTML:

$('#test-ul li[name=book]').text(); // 'Java & JavaScript' $('#test-ul li[name=book]').html(); // 'Java &amp; JavaScript' 

如何設置文本或HTML?jQuery的API設計非常巧妙:無參數調用text()是獲取文本,傳入參數就變成設置文本,

它的方法實際上會作用在對應的每個DOM節點上。

$('#test-ul li').text('JS'); // 是不是兩個節點都變成了JS? 

所以jQuery對象的另一個好處是我們可以執行一個操作,作用在對應的一組DOM節點上。

即使選擇器沒有返回任何DOM節點,調用jQuery對象的方法仍然不會報錯:

// 如果不存在id為not-exist的節點: $('#not-exist').text('Hello'); // 代碼不報錯,沒有節點被設置為'Hello' 

這意味着jQuery幫你免去了許多if語句

修改CSS

jQuery對象有“批量操作”的特點,這用於修改CSS實在是太方便了。考慮下面的HTML結構:

<!-- HTML結構 --> <ul id="test-css"> <li class="lang dy"><span>JavaScript</span></li> <li class="lang"><span>Java</span></li> <li class="lang dy"><span>Python</span></li> <li class="lang"><span>Swift</span></li> <li class="lang dy"><span>Scheme</span></li> </ul> 

調用jQuery對象的css('name', 'value')方法,我們用一行語句實現:

$('#test-css li.dy>span').css('background-color', '#ffd351').css('color', 'red');

jQuery對象的css()方法可以這么用:

var div = $('#test-div'); div.css('color'); // '#000033', 獲取CSS屬性 div.css('color', '#336699'); // 設置CSS屬性 div.css('color', ''); // 清除CSS屬性 

為了和JavaScript保持一致,CSS屬性可以用'background-color''backgroundColor'兩種格式。

css()方法將作用於DOM節點的style屬性,具有最高優先級

如果要修改class屬性,可以用jQuery提供的下列方法:

var div = $('#test-div'); div.hasClass('highlight'); // false, class是否包含highlight div.addClass('highlight'); // 添加highlight這個class div.removeClass('highlight'); // 刪除highlight這個class

map():
map() 把每個元素通過函數傳遞到當前匹配集合中,生成包含返回值的新的 jQuery 對象。

構建表單中所有值的列表:

$("p").append( $("input").map(function(){ return $(this).val(); }).get().join(", ") );

.map() 方法對於獲得或設置元素集的值特別有用。
<form method="post" action="">
  <fieldset>
    <div>
      <label for="two">2</label>
      <input type="checkbox" value="2" id="two" name="number[]">
    </div>
    <div>
      <label for="four">4</label>
      <input type="checkbox" value="4" id="four" name="number[]">
    </div>
    <div>
      <label for="six">6</label>
      <input type="checkbox" value="6" id="six" name="number[]">
    </div>
    <div>
      <label for="eight">8</label>
      <input type="checkbox" value="8" id="eight" name="number[]">
    </div>
  </fieldset>
</form>

我們能夠獲得復選框 ID 組成的逗號分隔的列表:

$(':checkbox').map(function() { return this.id; }).get().join(',');
本次調用的結果是字符串:"two,four,six,eight"。

顯示和隱藏DOM

考慮到顯示和隱藏DOM元素使用非常普遍,jQuery直接提供show()hide()方法,我們不用關心它是如何修改display屬性的,總之它能正常工作:

var a = $('a[target=_blank]'); a.hide(); // 隱藏 a.show(); // 顯示

獲取DOM信息

利用jQuery對象的若干方法,我們直接可以獲取DOM的高寬等信息,而無需針對不同瀏覽器編寫特定代碼:

// 瀏覽器可視窗口大小: $(window).width(); // 800 $(window).height(); // 600
// 某個div的大小: var div = $('#test-div'); div.width(); // 600 div.height(); // 300 div.width(400); // 設置CSS屬性 width: 400px,是否生效要看CSS是否有效 div.height('200px'); // 設置CSS屬性 height: 200px,是否生效要看CSS是否有效 

attr()removeAttr()方法用於操作DOM節點的屬性:

// <div id="test-div" name="Test" start="1">...</div> var div = $('#test-div'); div.attr('data'); // undefined, 屬性不存在 div.attr('name'); // 'Test' div.attr('name', 'Hello'); // div的name屬性變為'Hello' div.removeAttr('name'); // 刪除name屬性 div.attr('name'); // undefined

操作表單

對於表單元素,jQuery對象統一提供val()方法獲取和設置對應的value屬性

/* <input id="test-input" name="email" value=""> <select id="test-select" name="city"> <option value="BJ" selected>Beijing</option> <option value="SH">Shanghai</option> <option value="SZ">Shenzhen</option> </select> <textarea id="test-textarea">Hello</textarea> */ var input = $('#test-input'), select = $('#test-select'), textarea = $('#test-textarea'); input.val(); // 'test' input.val('abc@example.com'); // 文本框的內容已變為abc@example.com select.val(); // 'BJ' select.val('SH'); // 選擇框已變為Shanghai textarea.val(); // 'Hello' textarea.val('Hi'); // 文本區域已更新為'Hi'

可見,一個val()就統一了各種輸入框的取值和賦值的問題。

添加DOM

要添加新的DOM節點,除了通過jQuery的html()這種暴力方法外,還可以用append()方法,例如:

<div id="test-div"> <ul> <li><span>JavaScript</span></li> <li><span>Python</span></li> <li><span>Swift</span></li> </ul> </div> 

如何向列表新增一個語言?首先要拿到<ul>節點:

var ul = $('#test-div>ul'); 

然后,調用append()傳入HTML片段

ul.append('<li><span>Haskell</span></li>'); 

除了接受字符串,append()還可以傳入原始的DOM對象,jQuery對象和函數對象:

// 創建DOM對象: var ps = document.createElement('li'); ps.innerHTML = '<span>Pascal</span>'; // 添加DOM對象: ul.append(ps); // 添加jQuery對象: ul.append($('#scheme')); // 添加函數對象: ul.append(function (index, html) { return '<li><span>Language - ' + index + '</span></li>'; }); 

傳入函數時,要求返回一個字符串、DOM對象或者jQuery對象。因為jQuery的append()可能作用於一組DOM節點,只有傳入函數才能針對每個DOM生成不同的子節點。

append()把DOM添加到最后,prepend()則把DOM添加到最前。

另外注意,如果要添加的DOM節點已經存在於HTML文檔中,它會首先從文檔移除,然后再添加,也就是說,用append(),你可以移動一個DOM節點。

如果要把新節點插入到指定位置,例如,JavaScript和Python之間,那么,可以先定位到JavaScript,然后用after()方法:

var js = $('#test-div>ul>li:first-child'); js.after('<li><span>Lua</span></li>'); 

也就是說,同級節點可以用after()或者before()方法。

刪除節點

要刪除DOM節點,拿到jQuery對象后直接調用remove()方法就可以了。如果jQuery對象包含若干DOM節點,實際上可以一次刪除多個DOM節點:

var li = $('#test-div>ul>li'); li.remove(); // 所有<li>全被刪除
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM