热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

锋利的Jquery——学习笔记(四)DOM操作(一)

Jquery中的DOM操作(一)查找节点创建节点插入节点删除节点复制节点替换节点包裹节点属性操作样式操作设置和获取HTML、文本和值遍历节点css-dom操作一、查找节点1、查找元素节

Jquery中的DOM操作(一)

  • 查找节点
  • 创建节点
  • 插入节点
  • 删除节点
  • 复制节点
  • 替换节点
  • 包裹节点
  • 属性操作
  • 样式操作
  • 设置和获取HTML、文本和值
  • 遍历节点
  • css-dom操作

一、查找节点

1、查找元素节点

var li_txt=$("ul li:eq(2)").text();  //获取元素节点的文本内容
alert(li_txt);

2、查找属性节点

var p_txt=$("p").attr("title");

attr()方法中的第一个参数为属性的名字,第二个参数为设置值

$(selector).attr(attribute,value);

二、创建节点

1、创建元素节点

有两个步骤:
(1)创建元素节点:$(html)方法会根据传入的html标记字符串,创建dom对象,然后包装成jQuery对象返回
(2)将节点加入文档中:append()方法

var $li_1=$("
  • "
    );
    var $li_2=$("
  • "
    );
    $("ul").append($li_1);
    $("ul").append($li_2);

    2、创建文本节点

    var $li_3=$("<li><em>这是em><b>一个b><a href='#'>复杂的组合a>li>");
    $("ul").append($li_3);

    3、创建属性节点

    var $li_4=$("
  • ">西瓜
  • "
    );
    $("ul").append($li_4);

    三、插入节点

    插入节点的方法(将创建的元素插入到文档的不同位置)

    (1)append(); //像每个符合的元素追加内容

    $("ul").append($li_3);

    (2)appendTo(); //将所有匹配元素追加到指定的元素中

    $("
  • 猕猴桃
  • "
    ).appendTo("ul");

    (3)prepend(); //像每个匹配元素添加前置内容

    html:<p>我想说:p>
    js:$("p").prepend("<b>hahahahab>");
    结果为: <p><b>hahahahab>我想说:p>

    (4)prependTo(); //将所有匹配元素前置添加到指定的元素中

    js:$("hahahaha").prependTo("p");

    (5)after(); //插入到当前元素的后面,区分append()【插入到当前元素内部的最后面】
    (6)insertAfter(); // 和(5)插入的位置进行颠倒
    (7)before(); //插入到当前元素的前面,区分prepend()【插入到当前元素内部的最前边】
    (8)insertBefore(); // 和(7)插入的位置进行颠倒

    四、删除节点

    1、remove()

    根据传入的参数,删除所有匹配元素以及其后代节点,但是这个方法会返回一个删除节点的引用,可以在后续程序中继续应用。

    $li_1=$("ul li:eq(2)").remove();
    $li_1.appendTo("ul");
    $("ul li").remove("li[title!='苹果']");//可以在方法中添加条件

    2、empty()

    不是删除节点,而是清空节点中的内容。

    五、复制节点

    应用场景:在网上购物时,选中某个物品后,鼠标选中可以拖入购物车中

    $(this).clone(true).appendTo("ul[name='purchasecar']");//表示复制元素的同时,也复制该元素所绑定的事件

    六、替换节点

    1、replaceWith()

    $("p").replaceWith("<b>我是大好人b>");//效果是将原来的<p>我是大好人p>换为现在的<b>我是大好人b>

    2、replaceAll()

    用法与replaceWith使用恰好相反。
    注:当节点被替换以后,原来节点绑定的事件将会消失,需要重新绑定。

    七、包裹节点

    1、wrapAll()

    包裹节点,用wrapAll()方法是将所有匹配元素进行统一的包裹,但是wrap()是将每一个符合的元素节点进行单独的包裹。

    2、wrapInner()

    将每一个匹配元素的子内容(包括文本),用其他结构化标记包裹起来。


    推荐阅读
    • Voicewo在线语音识别转换jQuery插件的特点和示例
      本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
    • Html5-Canvas实现简易的抽奖转盘效果
      本文介绍了如何使用Html5和Canvas标签来实现简易的抽奖转盘效果,同时使用了jQueryRotate.js旋转插件。文章中给出了主要的html和css代码,并展示了实现的基本效果。 ... [详细]
    • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
      本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
    • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
    • 本文介绍了前端人员必须知道的三个问题,即前端都做哪些事、前端都需要哪些技术,以及前端的发展阶段。初级阶段包括HTML、CSS、JavaScript和jQuery的基础知识。进阶阶段涵盖了面向对象编程、响应式设计、Ajax、HTML5等新兴技术。高级阶段包括架构基础、模块化开发、预编译和前沿规范等内容。此外,还介绍了一些后端服务,如Node.js。 ... [详细]
    • 从零基础到精通的前台学习路线
      随着互联网的发展,前台开发工程师成为市场上非常抢手的人才。本文介绍了从零基础到精通前台开发的学习路线,包括学习HTML、CSS、JavaScript等基础知识和常用工具的使用。通过循序渐进的学习,可以掌握前台开发的基本技能,并有能力找到一份月薪8000以上的工作。 ... [详细]
    • 本文介绍了2015年九月八日的js学习总结及相关知识点,包括参考书《javaScript Dom编程的艺术》、js简史、Dom、DHTML、解释型程序设计和编译型程序设计等内容。同时还提到了最佳实践是将标签放到HTML文档的最后,并且对语句和注释的使用进行了说明。 ... [详细]
    • 本文介绍了Java后台Jsonp处理方法及其应用场景。首先解释了Jsonp是一个非官方的协议,它允许在服务器端通过Script tags返回至客户端,并通过javascript callback的形式实现跨域访问。然后介绍了JSON系统开发方法,它是一种面向数据结构的分析和设计方法,以活动为中心,将一连串的活动顺序组合成一个完整的工作进程。接着给出了一个客户端示例代码,使用了jQuery的ajax方法请求一个Jsonp数据。 ... [详细]
    • 本文总结了在编写JS代码时,不同浏览器间的兼容性差异,并提供了相应的解决方法。其中包括阻止默认事件的代码示例和猎取兄弟节点的函数。这些方法可以帮助开发者在不同浏览器上实现一致的功能。 ... [详细]
    • 获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法
      本文介绍了获取ul中第一个li元素的五种方法和多个ul中第一个li元素的四种方法,包括使用jQuery的选择器和遍历方法。通过这些方法,可以方便地获取到所需的元素,并进行相应的操作。 ... [详细]
    • 本文介绍了解决IE678伪类不兼容问题的方法,包括少用CSS3和HTML5独有的属性,使用CSS hacker,使用last-child清除浮动、批量添加标签、去掉list item最后一个的border-right等技巧。同时还介绍了使用after清除浮动时加上IE独有属性zoom:1的处理方法。另外,本文还提到可以使用jQuery代替批量添加标签的功能,以及使用负边距和CSS2选择器element+element去掉list item最后一个的border-right的方法。 ... [详细]
    • IjustinheritedsomewebpageswhichusesMooTools.IneverusedMooTools.NowIneedtoaddsomef ... [详细]
    • jQuery如何判断一个元素是否被点击?
      本文介绍了使用jQuery判断一个元素是否被点击的方法,并通过示例进行了具体说明。注意要指定父级,否则会执行多次。 ... [详细]
    • Jquery 跨域问题
      为什么80%的码农都做不了架构师?JQuery1.2后getJSON方法支持跨域读取json数据,原理是利用一个叫做jsonp的概念。当然 ... [详细]
    • 本文讨论了将HashRouter改为Router后,页面全部变为空白页且没有报错的问题。作者提到了在实际部署中需要在服务端进行配置以避免刷新404的问题,并分享了route/index.js中hash模式的配置。文章还提到了在vueJs项目中遇到过类似的问题。 ... [详细]
    author-avatar
    书友35194403
    这个家伙很懒,什么也没留下!
    PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有