【jQuery】$("#ID div").each(function(){ 如何只遍历子元素而非全部元素?

结构为:<divid="ID"><divid="1">内容1</div><divid="2"><divid="2_1">内容2.1</div><divid="2_1">内... 结构为:

<div id="ID">
<div id="1">内容1</div>

<div id="2">
<div id="2_1">内容2.1</div>
<div id="2_1">内容2.1</div>
</div>
<div id="3">内容3</div>
</div>
$("#ID div").each(function(){

这样写是遍历ID下所有的div。
如何才能只遍历#ID的子div,而不是全部div??也就是说如何才能不遍历id="2_1"和id="2_2"这两个div?
展开
 我来答
mxx米小夕
2018-03-31 · TA获得超过1.6万个赞
知道小有建树答主
回答量:5
采纳率:50%
帮助的人:4913
展开全部

遍历子元素:

jquery中遍历子元素,可以利用 $("#ul_tags>dl")  这种需要是直接的子节点,或 $("div#ul_tags:dl") 也是可以的,也可以直接使用$("div#ul_tags a")的形式。

jQuery:

jQuery是一个快速、简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架)。jQuery设计的宗旨是“write Less,Do More”,即倡导写更少的代码,做更多的事情。它封装JavaScript常用的功能代码,提供一种简便的JavaScript设计模式,优化HTML文档操作、事件处理、动画设计和Ajax交互。

jQuery的核心特性可以总结为:具有独特的链式语法和短小清晰的多功能接口;具有高效灵活的css选择器,并且可对CSS选择器进行扩展;拥有便捷的插件扩展机制和丰富的插件。jQuery兼容各种主流浏览器,如IE 6.0+、FF 1.5+、Safari 2.0+、Opera 9.0+等。

语言特点:

1.快速获取文档元素

jQuery的选择机制构建于Css的选择器,它提供了快速查询DOM文档中元素的能力,而且大大强化了JavaScript中获取页面元素的方式。

2.提供漂亮的页面动态效果

jQuery中内置了一系列的动画效果,可以开发出非常漂亮的网页,许多网站都使用jQuery的内置的效果,比如淡入淡出、元素移除等动态特效。

3.创建AJAX无刷新网页

AJAX是异步的JavaScript和ML的简称,可以开发出非常灵敏无刷新的网页,特别是开发服务器端网页时,比如PHP网站,需要往返地与服务器通信,如果不使用AJAX,每次数据更新不得不重新刷新网页,而使用AJAX特效后,可以对页面进行局部刷新,提供动态的效果。

4.提供对JavaScript语言的增强

jQuery提供了对基本JavaScript结构的增强,比如元素迭代和数组处理等操作。

5.增强的事件处理

jQuery提供了各种页面事件,它可以避免程序员在HTML中添加太事件处理代码,最重要的是,它的事件处理器消除了各种浏览器兼容性问题。

6.更改网页内容

jQuery可以修改网页中的内容,比如更改网页的文本、插入或者翻转网页图像,jQuery简化了原本使用JavaScript代码需要处理的方式。

罐头GG
2013-08-23 · 超过23用户采纳过TA的回答
知道答主
回答量:62
采纳率:0%
帮助的人:39.5万
展开全部

看来楼主要好好区分一下$("#ID>div")和$("#ID div")的区别了

        $("#ID div")在给定的祖先元素下匹配所有的后代元素

        $("#ID>div")在给定的父元素下匹配所有的子元素

        可以写个输出,看一下遍历的次数;

var i=1;
$("#ID div").each(function(){
 alert(i++);
 });
 $("#ID div").each//会遍历5次,        
 $("#ID>div").each//会遍历3次。

ps,楼上的$("#ID").children("div").each(function(){})这个也行

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
阿刚炖蛋
推荐于2018-02-27 · TA获得超过3004个赞
知道大有可为答主
回答量:1789
采纳率:92%
帮助的人:971万
展开全部

你好!


可以通过选择器来进行子元素或包含元素的限定!

要仔细看jquery的API。

$("#ID >div").each(function(){
          alert($(this).attr("id"));  //打印子div的ID
});
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
XfengcaoLF
2019-05-10 · TA获得超过210个赞
知道小有建树答主
回答量:382
采纳率:0%
帮助的人:125万
展开全部
each()配合find()来遍历元素最好这样就可以很简单的直接指定查找某个子元素的集合了
方法就是$(selector).find(selector).each(function(){
})
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
zc_hades
2013-08-22 · TA获得超过181个赞
知道小有建树答主
回答量:262
采纳率:0%
帮助的人:110万
展开全部
$("#ID").children("div").each(function(){})试试
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(4)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式