为了账号安全,请及时绑定邮箱和手机立即绑定
慕课网数字资源数据库体验端
jQuery基础(二)—DOM篇_学习笔记_慕课网
为了账号安全,请及时绑定邮箱和手机立即绑定

jQuery基础(二)—DOM篇

Aaron艾伦 Web前端工程师
难度入门
时长 2小时17分
  • //2个div合并成包含关系

     rightdiv.appendChild(rightaaron)

    //绘制到页面body

    body.appendChild(rightdiv)

    实现效果:

    <body>

    <div id='right'>

    <div id=aaron></div>

    </div>

    </body>

    查看全部
  • 首先li增加一个(新2)p的节点,然后这个整个结构跟着移动到刚才新增加的(新1)的节点后面,可以先点一次html结构,接着点一次元素背景变红,再点一次增加html可以发现背景色不存在的p元素是在最下面。

    如果appendto right的class里面,则是把li的整个标签包括新加的移出到了外面

    查看全部
  • 加了一个function之后相当于遍历执行,而不是整体执行

    查看全部
  • $("p:eq(1)").replaceWith('<a >替换第二段的内容</a>')

    通过jQuery筛选出第二个p元素,调用replaceWith进行替换,结果如下

    <div>
        <p>第一段</p>
        <a >替换第二段的内容</a>'
        <p>第三段</p>
    </div>


    查看全部
  • DOM节点删除之detach()和remove()区别

    通过一张对比表来解释2个方法之间的不同

    方法名

    参数

    事件及数据是否也被移除

    元素自身是否被移除

    remove

    支持选择器表达

    是(无参数时),有参数时要根据参数所涉及的范围

    detach

    参数同remove

    情况同remove

    remove:移除节点

    • 无参数,移除自身整个节点以及该节点的内部的所有节点,包括节点上事件与数据

    • 有参数,移除筛选出的节点以及该节点的内部的所有节点,包括节点上事件与数据

    detach:移除节点

    • 移除的处理与remove一致

    • 与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来

    • 例如:$("p").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。


    查看全部
  • 通过remove方法移除div及其内部所有元素,remove内部会自动操作事件销毁方法,所以使用使用起来非常简单

    //通过remove处理
    $('.hello').remove()
    //结果:<div class="hello"><p>慕课网</p></div> 全部被移除
    //节点不存在了,同事事件也会被销毁
    $("p").filter(":contains('3')").remove()


    查看全部
  • 创建为本节点:

    与创建元素节点类似,可以直接把文本内容一并描述

    $("<div>我是文本节点</div>")
    创建为属性节点:与创建元素节点同样的方式$("<div id='test' class='aaron'>我是文本节点</div>")


    查看全部
  • clone()方法是jQuery扩展的,只能处理通过jQuery绑定的事件与数据

    最新回答 / 慕神7001879

    我理解的是,一个元素上的事件还可以通过原生js添加,那么,这个时候,clone()就不能复制js添加的事件了。如下 var c=document.getElementsByClassName("aaron2")[0];        c.onclick=function(){            alert("1");        };通过js给.aaron2添加了点击事件,只会在原始元素上有效,clone()之后的元素上并无该事件。


    查看全部
    0 采集 收起 来源:DOM拷贝clone()

    2019-06-27

  • jQuery遍历之each()

    jQuery是一个合集对象,通过$()方法找到指定的元素合集后可以进行一系列的操作。比如我们操作$("li").css('') 给所有的li设置style值,因为jQuery是一个合集对象,所以css方法内部就必须封装一个遍历的方法,被称为隐式迭代的过程。要一个一个给合集中每一个li设置颜色,这里方法就是each

    .each() 方法就是一个for循环的迭代器,它会迭代jQuery对象合集中的每一个DOM元素。每次回调函数执行时,会传递当前循环次数作为参数(从0开始计数

    所以大体上了解3个重点:

    each是一个for循环的包装迭代器 each通过回调的方式处理,并且会有2个固定的实参,索引与元素 each回调方法中的this指向当前迭代的dom元素

    看一个简单的案例

    <ul>     <li>慕课网</li>     <li>Aaron</li> </ul>

    开始迭代li,循环2次

    $("li").each(function(index, element) {      index 索引 0,1      element是对应的li节点 li,li      this 指向的是li })

    这样可以在循环体会做一些逻辑操作了,如果需要提前退出,可以以通过返回 false以便在回调函数内中止循


    查看全部
  • jQuery遍历之add()方法

    jQuery是一个合集对象,通过$()方法找到指定的元素合集后可以进行一系列的操作。$()之后就意味着这个合集对象已经是确定的,如果后期需要再往这个合集中添加一新的元素要如何处理?jQuery为此提供add方法,用来创建一个新的jQuery对象 ,元素添加到匹配的元素集合中

    .add()的参数可以几乎接受任何的$(),包括一个jQuery选择器表达式,DOM元素,或HTML片段引用。

    简单的看一个案例:

    操作:选择所有的li元素,之后把p元素也加入到li的合集中

    <ul>     <li>list item 1</li>     <li>list item 3</li> </ul> <p>新的p元素</p>

    处理一:传递选择器

    $('li').add('p')

    处理二:传递dom元素

    $('li').add(document.getElementsByTagName('p')[0])

    还有一种方式,就是动态创建P标签加入到合集,然后插入到指定的位置,但是这样就改变元素的本身的排列了

     $('li').add('<p>新的p元素</p>').appendTo(目标位置)


    查看全部
  • jQuery遍历之siblings()

    jQuery是一个合集对象,如果想快速查找指定元素集合中每一个元素的同辈元素,此时可以用siblings()方法

    理解节点查找关系:

    如下蓝色的class="item-2"的li元素,红色的节点就是它的siblings兄弟节点

    <ul class="level-3">     <li class="item-1">1</li>     <li class="item-2">2</li>     <li class="item-3">3</li> </ul>

    siblings()无参数

    取得一个包含匹配的元素集合中每一个元素的同辈元素的元素集合

    注意:jQuery是一个合集对象,所以通过siblings是匹配合集中每一个元素的同辈元素

    siblings()方法选择性地接受同一类型选择器表达式

    同样的也是因为jQuery是合集对象,可能需要对这个合集对象进行一定的筛选,找出目标元素,所以允许传一个选择器的表达式


    查看全部
  • jQuery遍历之prev()方法

    jQuery是一个合集对象,如果想快速查找指定元素集合中每一个元素紧邻的前面同辈元素的元素集合,此时可以用prev()方法

    理解节点查找关系:

    如下蓝色的class="item-2"的li元素,红色的节点就是它的prev兄弟节点

    <ul class="level-3">     <li class="item-1">1</li>     <li class="item-2">2</li>     <li class="item-3">3</li> </ul>

    prev()无参数

    取得一个包含匹配的元素集合中每一个元素紧邻的前一个同辈元素的元素集合

    注意:jQuery是一个合集对象,所以通过prev是匹配合集中每一个元素的上一个兄弟元素

    prev()方法选择性地接受同一类型选择器表达式

    同样的也是因为jQuery是合集对象,可能需要对这个合集对象进行一定的筛选,找出目标元素,所以允许传一个选择器的表达式


    查看全部
  • jQuery遍历之next()方法

    jQuery是一个合集对象,如果想快速查找指定元素集合中每一个元素紧邻的后面同辈元素的元素集合,此时可以用next()方法

    理解节点查找关系:

    如下class="item-1"元素就是红色部分,那蓝色的class="item-2"就是它的兄弟元素

    <ul class="level-3">     <li class="item-1">1</li>     <li class="item-2">2</li>     <li class="item-3">3</li> </ul>

    next()无参数

    允许我们找遍元素集合中紧跟着这些元素的直接兄弟元素,并根据匹配的元素创建一个新的 jQuery 对象。

    注意:jQuery是一个合集对象,所以通过next匹配合集中每一个元素的下一个兄弟元素

    next()方法选择性地接受同一类型选择器表达式

    同样的也是因为jQuery是合集对象,可能需要对这个合集对象进行一定的筛选,找出目标元素,所以允许传一个选择器的表达式


    查看全部
  • jQuery遍历之closest()方法

    以选定的元素为中心,往内查找可以通过find、children方法。如果往上查找,也就是查找当前元素的父辈祖辈元素,jQuery提供了closest()方法,这个方法类似parents但是又有一些细微的区别,属于使用频率很高的方法

    closest()方法接受一个匹配元素的选择器字符串

    从元素本身开始,在DOM 树上逐级向上级元素匹配,并返回最先匹配的祖先元素

    例如:在div元素中,往上查找所有的li元素,可以这样表达

    $("div").closet("li')

    注意:jQuery是一个合集对象,所以通过closest是匹配合集中每一个元素的祖先元素

    closest()方法给定的jQuery集合或元素来过滤元素

    同样的也是因为jQuery是合集对象,可能需要对这个合集对象进行一定的筛选,找出目标元素,所以允许传一个jQuery的对象

    注意事项:在使用的时候需要特别注意下

    粗看.parents()和.closest()是有点相似的,都是往上遍历祖辈元素,但是两者还是有区别的,否则就没有存在的意义了

    1. 起始位置不同:.closest开始于当前元素 .parents开始于父元素

    2. 遍历的目标不同:.closest要找到指定的目标,.parents遍历到文档根元素,closest向上查找,直到找到一个匹配的就停止查找,parents一直查找到根元素,并将匹配的元素加入集合

    3. 结果不同:.closest返回的是包含零个或一个元素的jquery对象,parents返回的是包含零个或一个或多个元素的jquery对象


    查看全部
  • jQuery遍历之parents()方法

    jQuery是一个合集对象,如果想快速查找合集里面的每一个元素的所有祖辈元素,此时可以用parents()方法

    其实也类似find与children的区别,parent只会查找一级,parents则会往上一直查到查找到祖先节点

    理解节点查找关系:

    <div class="div">     <ul class="son">         <li class="grandson">1</li>     </ul> </div>

    在li节点上找到祖 辈元素div, 这里可以用$("li").parents()方法

    parents()无参数

    parents()方法允许我们能够在DOM树中搜索到这些元素的祖先元素,从有序的向上匹配元素,并根据匹配的元素创建一个新的 jQuery 对象;

    返回的元素秩序是从离他们最近的父级元素开始的

    注意:jQuery是一个合集对象,所以通过parent是匹配合集中所有元素的祖辈元素

    parents()方法选择性地接受同一型选择器表达式

    同样的也是因为jQuery是合集对象,可能需要对这个合集对象进行一定的筛选,找出目标元素,所以允许传一个选择器的表达式

    注意事项:

    1 .parents()和.parent()方法是相似的,但后者只是进行了一个单级的DOM树查找 2  $( "html" ).parent()方法返回一个包含document的集合,而$( "html" ).parents()返回一个空集合。


    查看全部

举报

0/150
提交
取消
课程须知
1、有HTML/CSS基础 2、有JavaScript基础
老师告诉你能学到什么?
1、jQuery的语法 2、jQuery节点操作
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!