jQuery之操做DOM

jQuery的選擇器很強大,用起來又簡單又靈活,可是搞了這麼久,我拿到了jQuery對象,到底要幹什麼?css

答案固然是操做對應的DOM節點啦!html

回顧一下修改DOM的CSS、文本、設置HTML有多麼麻煩,並且有的瀏覽器只有innerHTML,有的瀏覽器支持innerText,有了jQuery對象,不須要考慮瀏覽器差別了,所有統一操做!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:ide

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>jQuery</title>
<script src="/static/js/jquery-3.2.1.min.js"></script>
</head>
<body>
<ul id="test-ul">
<li class="js">JavaScript</li>
<li name="book">Java &amp; JavaScript</li>
</ul>
<script>
'use strict';
var r1 = $('#test-ul li[name=book]').text();// 'Java & JavaScript'
var r2 = $('#test-ul li[name=book]').html();// 'Java &amp; JavaScript'
console.log(r1);
console.log(r2);
</script>spa

</body>
</html>設計

結果:3d

如何設置文本或HTML?jQuery的API設計很是巧妙:無參數調用text()是獲取文本,傳入參數就變成設置文本,HTML也是相似操做,本身動手試試:code

 

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>jQuery</title>
<script src="/static/js/jquery-3.2.1.min.js"></script>
</head>
<body>
<ul id="test-ul">
    <li class="js">JavaScript</li>
    <li name="book">Java &amp; JavaScript</li>
</ul>
<script>
'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');
</script>

</body>
</html>

 

結果:htm

一個jQuery對象能夠包含0個或任意個DOM對象,它的方法實際上會做用在對應的每一個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')方法,咱們用一行語句實現:

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

注意,jQuery對象的全部方法都返回一個jQuery對象(多是新的也多是自身),這樣咱們能夠進行鏈式調用,很是方便。

jQuery對象的css()方法能夠這麼用:

ar 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

要隱藏一個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節點是不一樣的。

 

獲取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()就統一了各類輸入框的取值和賦值的問題。

 

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>jQuery</title>
<script src="/static/js/jquery-3.2.1.min.js"></script>
</head>
<body>
    <input id="test-input" name="email" value="test">
    <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>
<script>
'use strict';
var
   input = $('#test-input'),
   select = $('#test-select'),
   textarea = $('#test-textarea');

console.log(input.val());//'test'
input.val('xx@xx.com');//修改文本框的內容
console.log(input.val());//'xx@xx.com'

console.log(select.val());'BJ'
select.val('SH');
console.log(select.val());

console.log(textarea.val());
textarea.val('Hi');
console.log(textarea.val());

</script>

</body>
</html>

 

結果:

一個val()就統一了各類輸入框的取值和賦值的問題,是否是很easy呢。

相關文章
相關標籤/搜索