亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery操作DOM_動力節點Java學院整理

2019-11-19 16:10:57
字體:
來源:轉載
供稿:網友

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

答案當然是操作對應的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 & JavaScript</li></ul>

分別獲取文本和HTML:

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

如何設置文本或HTML?jQuery的API設計非常巧妙:無參數調用text()是獲取文本,傳入參數就變成設置文本,HTML也是類似操作,自己動手試試:

'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');

一個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()方法可以這么用:

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是否包含highlightdiv.addClass('highlight'); // 添加highlight這個classdiv.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(); // 600div.height(); // 300div.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.comselect.val(); // 'BJ'select.val('SH'); // 選擇框已變為Shanghaitextarea.val(); // 'Hello'textarea.val('Hi'); // 文本區域已更新為'Hi'

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美黑人一区二区三区| 狠狠躁夜夜躁人人爽超碰91| 亚洲高清久久久久久| 这里只有视频精品| 亚洲精品在线观看www| 久久精品国产免费观看| 久久99精品久久久久久琪琪| 91精品国产高清久久久久久91| 日本中文字幕久久看| 日本老师69xxx| 91在线观看免费观看| 97国产一区二区精品久久呦| 日韩亚洲综合在线| 亚洲最大福利视频网| 亚洲区免费影片| 国产午夜精品视频免费不卡69堂| 亚洲国产精品高清久久久| 久久久久久久亚洲精品| 欧美日韩综合视频网址| 不卡毛片在线看| 欧美有码在线观看视频| 亚洲一区二区三区在线免费观看| 久久久久久久一区二区| 日韩在线视频网站| 成人亚洲欧美一区二区三区| 午夜精品美女自拍福到在线| 亚洲免费一在线| 2019中文字幕在线免费观看| 久久天天躁狠狠躁夜夜躁| 精品福利在线观看| 91免费视频国产| 亚洲欧洲美洲在线综合| 91香蕉嫩草神马影院在线观看| 亚洲天堂视频在线观看| 国产成人精品视频| 欧美国产在线电影| 国产精品成人v| 久久久久99精品久久久久| 欧美色视频日本版| 成人国产在线激情| 热re91久久精品国99热蜜臀| 色综合91久久精品中文字幕| 日韩av日韩在线观看| 日韩成人性视频| 亚洲美女中文字幕| 国产精品久久色| 国产精品jizz在线观看麻豆| 在线观看日韩专区| 日韩av影视在线| 亚洲精品98久久久久久中文字幕| 欧美成人精品在线播放| 亚洲国产美女精品久久久久∴| 在线观看不卡av| 色综合久久久888| 亚洲毛片一区二区| 日韩在线观看免费av| 欧美俄罗斯性视频| 国产精品久久久久久久久影视| 精品无人国产偷自产在线| 日韩一区二区三区xxxx| 亚洲精品v欧美精品v日韩精品| 欧洲永久精品大片ww免费漫画| 久久精品视频播放| 成人亚洲综合色就1024| 国产盗摄xxxx视频xxx69| 欧美亚洲成人精品| 国产精品黄页免费高清在线观看| 亚洲欧美一区二区精品久久久| 亚洲国产高潮在线观看| 久久午夜a级毛片| 久久久久久久久久久成人| 亚洲电影中文字幕| 最近2019免费中文字幕视频三| 中文字幕在线观看亚洲| 成人欧美一区二区三区黑人孕妇| 亚洲性夜色噜噜噜7777| 亚洲国产精品成人va在线观看| 在线观看视频99| 国产视频在线一区二区| 国产在线观看91精品一区| 国产精品久久久久av| 国产精品欧美一区二区三区奶水| 国产精品免费在线免费| 欧美激情一区二区三级高清视频| 性欧美亚洲xxxx乳在线观看| 欧美日韩国产综合视频在线观看中文| 欧美性受xxxx黑人猛交| 亚洲sss综合天堂久久| 久久久精品2019中文字幕神马| 97免费视频在线播放| 国产成人啪精品视频免费网| 亚洲午夜精品久久久久久久久久久久| 亚洲美女精品久久| 国产精品九九久久久久久久| 伊人伊人伊人久久| 成人看片人aa| 亚洲日韩中文字幕在线播放| 日韩美女在线观看| 青青精品视频播放| 亚洲一级黄色片| 亚洲少妇中文在线| 成人免费视频xnxx.com| 青青草99啪国产免费| 神马久久久久久| www.99久久热国产日韩欧美.com| 日韩在线视频中文字幕| 亲爱的老师9免费观看全集电视剧| 亚洲图片欧洲图片av| 精品成人在线视频| 欧美性高跟鞋xxxxhd| 亲爱的老师9免费观看全集电视剧| 国产精品777| 欧美激情一区二区三区成人| 亚洲精品乱码久久久久久金桔影视| 91久久中文字幕| 一本色道久久综合狠狠躁篇的优点| 久久99热这里只有精品国产| 国产精品精品视频| 91av视频在线播放| 伊人男人综合视频网| 免费av一区二区| 日韩美女激情视频| 日韩精品视频免费在线观看| www.亚洲人.com| 亚洲精品av在线播放| 久久免费少妇高潮久久精品99| 91视频国产一区| 亚州国产精品久久久| 精品无人国产偷自产在线| 亚洲欧美激情精品一区二区| 久久久久在线观看| 国精产品一区一区三区有限在线| 欧美亚洲激情在线| 欧美激情亚洲精品| 亚洲女人天堂成人av在线| 国产福利精品在线| 国产亚洲aⅴaaaaaa毛片| 亚洲第一区在线观看| 国产精品一区二区女厕厕| 国产午夜精品美女视频明星a级| 国产一区二区三区视频免费| 欧美国产精品日韩| 欧美日韩亚洲91| 久久99国产精品自在自在app| 亚洲精品白浆高清久久久久久| 亚洲欧美日韩爽爽影院| 久久久久亚洲精品成人网小说| 57pao国产精品一区| 黑人狂躁日本妞一区二区三区| 国产一区二区三区视频| 久久91超碰青草是什么| 亚洲免费一级电影| 日韩欧美亚洲国产一区| 亚洲精品一二区| 欧美综合在线第二页| 成人网在线观看| 精品中文字幕视频| 日韩欧美高清在线视频| 精品国产区一区二区三区在线观看| 26uuu日韩精品一区二区| 丝袜美腿亚洲一区二区| 91网站在线免费观看| 日本成熟性欧美| 精品国产一区久久久|