JQuery元素快速查找与操作
首先,我们来看看jquery中如何查找到想要的结点。
第一步:sizzle选择器
基于元素的id、类、类型、属性、属性值等"查找"(或选择)html元素,简单的说是基于css选择器,除此之外还有一些特定的选择器。
第二步:查询祖先
parent()
返回被选元素的直接父元素,该方法只会向上一级对 dom 树进行遍历
parents()
可以使用可选参数来过滤对父元素的搜索
返回被选元素的所有祖先元素,它一路向上直到文档的根元素
parentsuntil()
返回介于两个给定元素之间的所有祖先元素,下面是例子:
$(document).ready(function(){ //会返回span开始到div为止的祖先元素 $("span").parentsuntil("div"); });
第三步:查询子孙
children()
可以使用可选参数来过滤对子元素的搜索
返回被选元素的所有直接子元素,该方法只会向下一级对 dom 树进行遍历
find()
可以使用可选参数来过滤对元素的搜索
返回被选元素的后代元素,一路向下直到最后一个后代
第四步:查询同胞
siblings()
返回被选元素的所有同胞元素
next()
返回被选元素的下一个同胞元素
nextall()
返回被选元素的之后的全部同胞元素
nextuntil()
返回介于两个给定参数之间的所有跟随的同胞元素
$(document).ready(function(){ //返回介于 <h2>与<h6>元素之间的所有同胞元素 $("h2").nextuntil("h6"); });
prev()、prevall() 和 prevuntil()
prev()、prevall()以及prevuntil()方法的工作方式与上面的方法类似,只不过方向相反而已:它们返回的是前面的同胞元素(在 dom 树中沿着同胞之前元素遍历,而不是之后元素遍历)。
第五步:查询时添加过滤
first()
返回选择的元素中的首个元素
last()
返回选择的元素中的最后一个元素
eq()
返回被选元素中带有指定索引号的元素,这个很容易理解,举例就是:$(element[flag])和element.eq(flag)结果一样
filter()
对查询结果进行过滤,和下面not()类似,作用相反
not()
返回不匹配标准的所有元素
$(document).ready(function(){ //返回不带有类名"target"的所有p元素 $("p").not(".target"); });
元素找到以后,接着我们需要根据需求来对查找到的结点进行操作。
第六步:text()、html()、val()以及attr()
text()、html()、val()以及attr(),拥有回调函数。回调函数有两个参数:被选元素列表中当前元素的下标,以及原始(旧的)值。然后以函数新值返回您希望使用的字符串
1.text() - 设置或返回所选元素的文本内容
2.html() - 设置或返回所选元素的内容(包括 html 标记)
3.val() - 设置或返回表单字段的值
4.attr() - 设置或返回属性值
$("#btn1").click(function(){ $("#test1").text(function(i,origtext){ return "旧文本: " + origtext + " 新文本: index: " + i; }); });
第七步:添加元素
append() - 在被选元素的内部结尾插入内容
prepend() - 在被选元素的内部开头插入内容
after() - 在被选元素之后插入内容
before() - 在被选元素之前插入内容
第八步:删除元素
remove()可接受一个参数,允许你对被删元素进行过滤,empty()不可以
remove() - 删除被选元素(及其子元素)
empty() - 从被选元素中删除子元素
//等同于$("p.target").remove(); $("p").remove(".target");
第九步:替换元素
replaceall()和replacewith()功能类似,但是目标和源相反
replacewith() - 用提供的内容替换集合中所有匹配的元素并且返回被删除元素的集合
replaceall() - 用集合的匹配元素替换每个目标元素
第十步:class操作
addclass() - 向被选元素添加一个或多个类
removeclass() - 从被选元素删除一个或多个类
toggleclass() - 对被选元素进行添加/删除类的切换操作
hasclass() - 判断一个元素是否存在该class
第十一步:css()方法
设置或返回被选元素的一个或多个样式属性
css("propertyname"); - 返回propertyname属性的值
css("propertyname","value"); - 设置propertyname属性的值
css({"propertyname":"value","propertyname":"value",...}); - 设置多个值
第十二步:元素尺寸
width() 方法设置或返回元素的宽度(不包括内边距、边框或外边距)
height() 方法设置或返回元素的高度(不包括内边距、边框或外边距)
innerwidth() 方法返回元素的宽度(包括内边距)
innerheight() 方法返回元素的高度(包括内边距)
outerwidth() 方法返回元素的宽度(包括内边距和边框)
outerheight() 方法返回元素的高度(包括内边距和边框)