《jQuery零基礎入門》系列博文是在廖雪峯老師的博文基礎上,可能補充了我的的理解和平常遇到的點,用個人理解表述出來,主幹出處來自廖雪峯老師的技術分享。javascript
jQuery強大的選擇器,最終目的是咱們能夠用來操做DOM節點,這一節課,咱們來聊聊怎麼用jQuery來操做DOM。css
在JS中,咱們操做DOM,好比修改DOM的樣式、文本或屬性,其實特別的麻煩,有時候還得考慮兼容性問題,例若有的瀏覽器支持innerHTML,有的瀏覽器支持innerText。不過有了咱們的jQuery就不用怕了,不用考慮那麼多,它一次性解決。html
jQuery對象的text()
和html()
方法分別獲取節點的文本和原始HTML文本,例如,以下的HTML結構:java
<!-- HTML結構 --> <ul id="test-ul"> <li class="js">JavaScript</li> <li name="book">Java & JavaScript</li> </ul>
運行結果:瀏覽器
分別獲取文本和HTML:ide
$('#test-ul li[name=book]').text(); // 'Java & JavaScript' $('#test-ul li[name=book]').html(); // 'Java & JavaScript'
如何設置文本或HTML?jQuery的API設計很是巧妙:無參數調用text()
是獲取文本,傳入參數就變成設置文本,HTML也是相似操做,本身動手試試:spa
'use strict'; var j1 = $('#test-ul li.js'); var j2 = $('#test-ul li[name=book]'); j1.html('<span style="color: red">JavaScript</span>'); j2.text('JavaScript & ECMAScript');
執行完以後你會發現,上邊的HTML輸出變成了:設計
一個jQuery對象能夠包含0個或任意個DOM對象,它的方法實際上會做用在對應的每一個DOM節點上。在上面的例子中試試:code
$('#test-ul li').text('JS'); // 是否是兩個節點都變成了JS?
因此jQuery對象的另外一個好處是咱們能夠執行一個操做,做用在對應的一組DOM節點上。即便選擇器沒有返回任何DOM節點,調用jQuery對象的方法仍然不會報錯:htm
// 若是不存在id爲not-exist的節點: $('#not-exist').text('Hello'); // 代碼不報錯,沒有節點被設置爲'Hello'
這意味着jQuery幫你免去了許多if
語句。
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對象的全部方法都返回一個jQuery對象(多是新的也多是自身),這樣咱們能夠進行鏈式調用,很是方便。
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
要隱藏一個DOM,咱們能夠設置CSS的display
屬性爲none
,利用css()
方法就能夠實現。不過,要顯示這個DOM就須要恢復原有的display
屬性,這就得先記下來原有的display
屬性究竟是block
仍是inline
仍是別的值。
考慮到顯示和隱藏DOM元素使用很是廣泛,jQuery直接提供show()
和hide()
方法,咱們不用關心它是如何修改display
屬性的,總之它能正常工做:
var a = $('a[target=_blank]'); a.hide(); // 隱藏 a.show(); // 顯示
注意,隱藏DOM節點並未改變DOM樹的結構,它隻影響DOM節點的顯示。這和刪除DOM節點是不一樣的。
利用jQuery對象的若干方法,咱們直接能夠獲取DOM的高寬等信息,而無需針對不一樣瀏覽器編寫特定代碼:
// 瀏覽器可視窗口大小: $(window).width(); // 800 $(window).height(); // 600 // HTML文檔大小: $(document).width(); // 800 $(document).height(); // 3500 // 某個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
prop()
方法和attr()
相似,可是HTML5規定有一種屬性在DOM節點中能夠沒有值,只有出現與不出現兩種,例如:
<input id="test-radio" type="radio" name="test" checked value="1">
等價於:
<input id="test-radio" type="radio" name="test" checked="checked" value="1">
attr()
和prop()
對於屬性checked
處理有所不一樣
var radio = $('#test-radio'); radio.attr('checked'); // 'checked' radio.prop('checked'); // true
prop()
返回值更合理一些。不過,用is()
方法判斷更好:
var radio = $('#test-radio'); radio.is(':checked'); // true
相似的屬性還有selected
,處理時最好用is(':selected')
。
對於表單元素,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()
就統一了各類輸入框的取值和賦值的問題。