欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解jQuery中的元素的屬性和相關(guān)操作

 更新時(shí)間:2015年08月14日 11:14:22   作者:libuchao  
這篇文章主要介紹了詳解jQuery中的元素的屬性和相關(guān)操作,jQuery是最為流行的JavaScript庫(kù),需要的朋友可以參考下

元素屬性

元素的屬性中可以包含很多有用的信息,所以如何設(shè)置或得到屬性中的值,就顯得非常重要。

jQuery 的 $.fn.attr 方法可以作為 setter 和 getter 使用,用來(lái)設(shè)置或獲取屬性的值。和 $.fn.css 用法類似,$.fn.attr 既可一次性接受單個(gè)屬性,也可以接受多個(gè)屬性(對(duì)象) :

$('a').attr('href', 'allMyHrefsAreTheSameNow.html');
$('a').attr({
  'title' : 'all titles are the same too!',
  'href' : 'somethingNew.html'
});

上面代碼中寫對(duì)象的時(shí)候?qū)懗啥嘈辛?,更具可讀性。

$('a').attr('href'); // 返回選擇其中第一個(gè)超鏈接的鏈接地址

一旦選擇器的結(jié)果集中有元素了,就可以這些元素為基準(zhǔn)點(diǎn)遍歷其它元素了。關(guān)于 jQuery 遍歷元素的方法,詳見(jiàn) http://api.jquery.com/category/traversing/,如:

$('h1').next('p');
$('div:visible').parent();
$('input[name=first_name]').closest('form');
$('#myList').children();
$('li.selected').siblings();

還可以用 $.fn.each 方法,對(duì)結(jié)果集中的元素一個(gè)一個(gè)處理:

$('#myList li').each(function(idx, el) {
  console.log(
    'Element ' + idx +
    'has the following html: ' +
    $(el).html()
  );
});

移動(dòng)、復(fù)制、刪除元素

如果要移動(dòng)一個(gè)元素的位置:

// 把第一個(gè)列表移至最后
var $li = $('#myList li:first').appendTo('#myList');

// 另外一種方法,也能達(dá)到同樣效果
$('#myList').append($('#myList li:first'));

復(fù)制一個(gè)元素

// 把第一個(gè) li 做一份拷貝,然后放置列表的最后
$('#myList li:first').clone().appendTo('#myList');

如果復(fù)制元素的時(shí)候,想把元素的屬性和事件等信息也一起復(fù)制了的話,調(diào)用 $.fn.clone 的時(shí)候給個(gè)參數(shù) true 就 OK 了。

再說(shuō)刪除元素,jQuery 中各有兩種方法可以刪除元素:$.fn.remove 和 $.fn.detach,這兩個(gè)方法都可以從頁(yè)面中刪除元素,并且這兩種方法的返回值都是被刪除的元素,區(qū)別是 $.fn.remove 的返回的元素中的不再包含元素的一些附屬信息,如 id 和 class 等信息,也不包括元素上綁定的事件。$.fn.detach 則不同,將被刪除元素中的附屬信息和事件也一并保存了下來(lái),具體是用哪種,要看實(shí)際需求了。
創(chuàng)建新元素

jQuery 可以很快捷的換件新元素:

$('<p>這是一個(gè)新段落</p>');
$('<li class="new">新列表元素</li>');

$('<a/>', {
  html : '這是一個(gè) <strong>新</strong> 超鏈接',
  'class' : 'new',
  href : 'foo.html'
});

注意上面?zhèn)魅氲?JavaScript 對(duì)象,里面的第二個(gè)屬性 class 被加了引號(hào),因?yàn)?class 是 JavaScript 的保留字,html 和 href 不是,所以不需要加引號(hào)。

創(chuàng)建新元素后,新元素并不會(huì)自動(dòng)加入到頁(yè)面中。加入頁(yè)面中的話,可以用下面的方法:

var $myNewElement = $('<p>New element</p>');
$myNewElement.appendTo('#content');

$myNewElement.insertAfter('ul:last'); // 此操作會(huì)把 p 元素從 #content 中移除
$('ul').last().after($myNewElement.clone()); // 當(dāng)然也可以克隆一個(gè)出來(lái),現(xiàn)在 #content 中有兩個(gè) p 了哦

嚴(yán)格來(lái)說(shuō),不是一定要將新創(chuàng)建的元素保存在一個(gè)變量中,可以在創(chuàng)建后直接加入頁(yè)面內(nèi)。但是很多時(shí)候新創(chuàng)建的元素都要被多次使用,所以要緩存在一個(gè)變量中,這樣不用重復(fù)去創(chuàng)建它了。

你甚至可以在向頁(yè)面添加元素時(shí)創(chuàng)建它,但是這種情況下無(wú)法獲得新創(chuàng)建元素的引用:

$('ul').append('<li>list item</li>');

往頁(yè)面中添加新元素非常簡(jiǎn)單,但是如果需要向頁(yè)面新加很多很多個(gè)元素的話,可能會(huì)有性能問(wèn)題。因?yàn)槊看蜗蝽?yè)面中添加元素,整個(gè)頁(yè)面的 HTML 都要作為字符串參與拼接,這是非常耗費(fèi)性能的。這種情況下,通常有以下處理方法:

var myItems = [], $myList = $('#myList');

for (var i=0; i<100; i++) {
  myItems.push('<li>item ' + i + '</li>');
}

$myList.append(myItems.join(''));

相關(guān)文章

  • jQuery中clone()方法用法實(shí)例

    jQuery中clone()方法用法實(shí)例

    這篇文章主要介紹了jQuery中clone()方法用法,實(shí)例分析了clone()方法的功能、定義及克隆匹配的DOM元素的使用技巧,需要的朋友可以參考下
    2015-01-01
  • JQuery的常用選擇器、過(guò)濾器、方法全面介紹

    JQuery的常用選擇器、過(guò)濾器、方法全面介紹

    下面小編就為大家?guī)?lái)一篇JQuery的常用選擇器、過(guò)濾器、方法全面介紹。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-05-05
  • jquery利用ajax調(diào)用后臺(tái)方法實(shí)例

    jquery利用ajax調(diào)用后臺(tái)方法實(shí)例

    這篇文章介紹了jquery利用ajax調(diào)用后臺(tái)方法實(shí)例,有需要的朋友可以參考一下
    2013-08-08
  • jQuery簡(jiǎn)單動(dòng)畫(huà)變換效果實(shí)例分析

    jQuery簡(jiǎn)單動(dòng)畫(huà)變換效果實(shí)例分析

    這篇文章主要介紹了jQuery簡(jiǎn)單動(dòng)畫(huà)變換效果,結(jié)合實(shí)例形式分析了jQuery使用toggle及animate等方法動(dòng)態(tài)操作頁(yè)面元素樣式的相關(guān)技巧,需要的朋友可以參考下
    2016-07-07
  • jquery中$.post()方法的簡(jiǎn)單實(shí)例

    jquery中$.post()方法的簡(jiǎn)單實(shí)例

    本篇文章主要是對(duì)jquery中$.post()方法的簡(jiǎn)單實(shí)例進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助
    2014-02-02
  • JQuery標(biāo)簽頁(yè)效果實(shí)例詳解

    JQuery標(biāo)簽頁(yè)效果實(shí)例詳解

    這篇文章主要介紹了JQuery標(biāo)簽頁(yè)效果,結(jié)合實(shí)例形式較為詳細(xì)的分析了jQuery響應(yīng)鼠標(biāo)事件動(dòng)態(tài)遍歷及切換標(biāo)簽頁(yè)的技巧,需要的朋友可以參考下
    2015-12-12
  • jQuery動(dòng)態(tài)改變圖片顯示大小(修改版)的實(shí)現(xiàn)思路及代碼

    jQuery動(dòng)態(tài)改變圖片顯示大小(修改版)的實(shí)現(xiàn)思路及代碼

    這篇文章主要介紹了jQuery動(dòng)態(tài)改變圖片顯示大小(修改版)的實(shí)現(xiàn)思路及代碼,有需要的朋友可以參考一下
    2013-12-12
  • JQuery中$(document)是什么意思有什么作用

    JQuery中$(document)是什么意思有什么作用

    $(document).ready(fn):當(dāng)DOM載入就緒可以查詢及操縱時(shí)綁定一個(gè)要執(zhí)行的函數(shù),因?yàn)樗梢詷O大地提高web應(yīng)用程序的響應(yīng)速度
    2014-07-07
  • 基于jquery animate操作css樣式屬性小結(jié)

    基于jquery animate操作css樣式屬性小結(jié)

    昨天突然有網(wǎng)友問(wèn)我animate()方法可以來(lái)操作所有css屬性嗎?是的,我告訴他可以的。不過(guò),在此有需要注意點(diǎn)需要大家搞清楚。接下來(lái)通過(guò)本篇文章給大家介紹基于jquery animate操作css樣式屬性小結(jié),對(duì)jquery animate css相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2015-11-11
  • Jquery中.bind()、.live()、.delegate()和.on()之間的區(qū)別詳解

    Jquery中.bind()、.live()、.delegate()和.on()之間的區(qū)別詳解

    在我們?nèi)粘i_(kāi)發(fā)中經(jīng)常會(huì)使用到.bind()、.live()、.delegate()和.on(),有些同學(xué)會(huì)對(duì)這四者存在一些疑慮,所以下面這篇文章主要給大家介紹了關(guān)于Jquery中.bind()、.live()、.delegate()和.on()之間區(qū)別的相關(guān)資料,需要的朋友可以參考借鑒。
    2017-08-08

最新評(píng)論