元素属性
元素的属性中可以包含很多有用的信息,所以如何设置或得到属性中的值,就显得非常重要。
jQuery 的 $.fn.attr 方法可以作为 setter 和 getter 使用,用来设置或获取属性的值。和 $.fn.css 用法类似,$.fn.attr 既可一次性接受单个属性,也可以接受多个属性(对象) :
$('a').attr('href', 'allMyHrefsAreTheSameNow.html');
$('a').attr({
'title' : 'all titles are the same too!',
'href' : 'somethingNew.html'
});上面代码中写对象的时候写成多行了,更具可读性。
$('a').attr('href'); // 返回选择其中第一个超链接的链接地址一旦选择器的结果集中有元素了,就可以这些元素为基准点遍历其它元素了。关于 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 方法,对结果集中的元素一个一个处理:
$('#myList li').each(function(idx, el) {
console.log(
'Element ' + idx +
'has the following html: ' +
$(el).html()
);
});移动、复制、删除元素
如果要移动一个元素的位置:
// 把第一个列表移至最后
var $li = $('#myList li:first').appendTo('#myList');// 另外一种方法,也能达到同样效果
$('#myList').append($('#myList li:first'));
复制一个元素
// 把第一个 li 做一份拷贝,然后放置列表的最后
$('#myList li:first').clone().appendTo('#myList');如果复制元素的时候,想把元素的属性和事件等信息也一起复制了的话,调用 $.fn.clone 的时候给个参数 true 就 OK 了。
再说删除元素,jQuery 中各有两种方法可以删除元素:$.fn.remove 和 $.fn.detach,这两个方法都可以从页面中删除元素,并且这两种方法的返回值都是被删除的元素,区别是 $.fn.remove 的返回的元素中的不再包含元素的一些附属信息,如 id 和 class 等信息,也不包括元素上绑定的事件。$.fn.detach 则不同,将被删除元素中的附属信息和事件也一并保存了下来,具体是用哪种,要看实际需求了。
创建新元素
jQuery 可以很快捷的换件新元素:
$('<p>这是一个新段落</p>');
$('<li class="new">新列表元素</li>');










