jQuery后代遍历总结

四世同堂的喜事可不是每一个人都能遇得到的。每个家族中都会有家长也会有后代,后代的包含的对象除了子代还包含孙代以及后续说有的代。我国传统文化中就包含有“尊老爱幼”的美德,根据相对论来讲,我们每个人都会成为先辈,也都是其他先辈的后代。

高级形态的智慧生物人为什么会从哺乳动物这一支进化而来,不是没有任何道理的。长期的哺乳活动能促进母亲和后代之间的交流,家庭的基础就是建立在这个之上。很难想象如果人一出生就想羚羊一样撒开腿就能跑,估计人和自己的母亲就不会有那么深的感情。家庭也会变得很不稳定,人类社会的基石就会动摇。巴拉巴拉说了这么多就为了引出后代这个概念。

母猪在给小猪喂奶

虽然在生物界后代的概念无比重要,代表了基因的顺利传递。在jQuery中后代的意义只不过是DOM模型的层级的差异,虽然没有生物学中的意义重要,但是如果我们想要像操作自己手臂一样的操作DOM,后代遍历的方法我们还是要掌握理解的。

以前的文章《jQuery祖先遍历总结》中介绍了在jQuery中祖先遍历的三种方法,我们使用这些方法能在DOM中任意的向上层的节点“移动”查找上级元素。这篇文章就总结下如何在DOM向下层的节点“移动”查找下级元素,即后代遍历。

jQuery后代遍历的方法有两个比祖先遍历少了一个。它们分别是children()find()。我们先来说下children()方法。

children()方法的作用是返回所选元素的所有直接子元素。这里面的直接子元素就意味着,我们children()方法只能向下移动一级遍历。

举例说明问题:

//jquery code

$(document).ready(function(){

  $("div").children().css({"color":"red","border":"2px solid red"});

//让div的下一级子元素的字体颜色和边框颜色成红色;

});

//html code

<div>div  (当前元素)
  <p>p  (子)
    <span>span  (孙)</span>    
  </p>
  <p>p (child)
    <span>span (孙)</span>
  </p>
</div>

结果如下:

jquery children()方法demo

children()方法还可以选择“指定”的子元素。例如下面的代码就是在<div>的子元素中并选择出其中是<p class="active">的元素。如果只是子元素中的<p>没有添加任何类或者不含active类的<p>及子元素中非<p>的元素则不会被选中。

$(document).ready(function(){
  $("div").children("p.active");
});

介绍完了children()方法之后,就剩下一个find()方法了。足够聪明的你一定猜到了jQuery这么优秀的库,如果只能遍历下一级子元素,不然也太不灵活了,那么这个find()方法应该就是遍历所有后代元素的方法了。哈哈~太对了。children()方法就是返回被选元素所有后代元素,它威风凛凛一插到底,一直到被选元素分支中最后一个的后代元素。

//jquery code

$(document).ready(function(){
$("div").find("span").css({"color":"red","border":"2px solid red"});
//让div的后代元素span的字体颜色和边框颜色成红色;
});

//html code
<div>div  (current element)
  <p>p  (子)
    <span>span  (孙)</span>    
  </p>
  <p>p (child)
    <span>span (孙)</span>
  </p>
</div>

结果如下:

jquery find()方法demo

find()方法同样能灵活的选择“指定”的后代元素,使用方式和上文中的children()是一样的。

简单的积木也能搭建雄伟的大桥,这些简单的方法就是组成实现复杂功能程序的基础零件。能灵活运用并理解它们的知识,绝对是我们提升自我过程中不小助力。目前我们已经盘点了祖先遍历和后代遍历,这两种方法已经可以让我们在DOM树中自由的上下“移动”选择我们想要操作的元素了。嘿嘿~是不是有点小兴奋啊?

(报告完毕!)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,386评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,142评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,704评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,702评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,716评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,573评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,314评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,230评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,680评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,873评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,991评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,706评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,329评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,910评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,038评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,158评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,941评论 2 355

推荐阅读更多精彩内容

  • 通过jQuery,您可以选取(查询,query)HTML元素,并对它们执行“操作”(actions)。 jQuer...
    枇杷树8824阅读 656评论 0 3
  • DOM创建节点及节点属性 通过JavaScript可以很方便的获取DOM节点,从而进行一系列的DOM操作。但实际上...
    阿r阿r阅读 1,017评论 0 9
  • 第1章 简介 第2章 DOM节点的创建 2-1 DOM创建节点及节点属性 通过JavaScript可以很方便的获...
    mo默22阅读 812评论 0 8
  • (续jQuery基础(1)) 第5章 DOM节点的复制与替换 (1)DOM拷贝clone() 克隆节点是DOM的常...
    凛0_0阅读 1,340评论 0 8
  • 1:jQuery节点创建与属性的处理 创建元素节点:可以有几种方式,后面会慢慢接触。常见的就是直接把这个节点的结构...
    码农小杨阅读 606评论 0 1