国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 11:49:35
字體:
供稿:網(wǎng)友

元素屬性

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

jQuery 的 $.fn.attr 方法可以作為 setter 和 getter 使用,用來設(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ū)懗啥嘈辛耍呖勺x性。

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

一旦選擇器的結(jié)果集中有元素了,就可以這些元素為基準(zhǔn)點(diǎn)遍歷其它元素了。關(guān)于 jQuery 遍歷元素的方法,詳見 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 了。

再說刪除元素,jQuery 中各有兩種方法可以刪除元素:$.fn.remove 和 $.fn.detach,這兩個(gè)方法都可以從頁面中刪除元素,并且這兩種方法的返回值都是被刪除的元素,區(qū)別是 $.fn.remove 的返回的元素中的不再包含元素的一些附屬信息,如 id 和 class 等信息,也不包括元素上綁定的事件。$.fn.detach 則不同,將被刪除元素中的附屬信息和事件也一并保存了下來,具體是用哪種,要看實(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)加入到頁面中。加入頁面中的話,可以用下面的方法:

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

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

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

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

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

var myItems = [], $myList = $('#myList');for (var i=0; i<100; i++) {  myItems.push('<li>item ' + i + '</li>');}$myList.append(myItems.join(''));

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 如东县| 图片| 开阳县| 尉氏县| 洪湖市| 广宗县| 江口县| 大渡口区| 休宁县| 柘城县| 新绛县| 繁昌县| 阳西县| 团风县| 沙洋县| 营山县| 武胜县| 宜章县| 秦皇岛市| 岳普湖县| 久治县| 从化市| 沈阳市| 东安县| 金川县| 淳安县| 湛江市| 渭南市| 广宁县| 武义县| 文登市| 化州市| 福安市| 句容市| 藁城市| 仙游县| 夏河县| 如东县| 清河县| 安康市| 四会市|