第七章 jQuery框架的选择器

jQuery框架继承和优化了JavaScript访问DOM对象的特性,我们使用jQuery框架提供的api可以更加方便的操作DOM对象。

7.1 创建DOM节点

使用JavaScript原生方式创建DOM节点并添加到页面中的代码示例:

 //01 创建DOM节点
var oDiv = document.createElement("div");
//02 设置DOM节点的内容
oDiv.innerText = "测试的DIV标签";
//03 把节点添加到页面中
document.body.appendChild(oDiv);

使用jQuery框架创建DOM节点并添加的代码示例:

 //01 创建DOM节点
var oDom = $("<div></div>");
//02 设置DOM节点的内容
oDom.text("测试的div标签");
//02 把DOM节点添加到页面中
$("body").append(oDom);

更简单的创建及添加方式:
$("body").append($("<div>我是测试的div标签</div>"));

说明

【1】jQuery框架简化了DOM操作,直接使用jQuery构造函数$()来创建标签,在创建标签的时候只需要把HTML字符串传递给函数,jQuery框架会根据参数的内容来创建标签并包装成一个jQ实例对象返回。

【2】要明白jQuery框架的DOM操作本身是对JavaScript原生方式进行的封装,所以相对原生的DOM操作而言效率更低

7.2 插入DOM节点

jQuery框架中提供了多个插入DOM节点的方法,我们可以通过调用这些方法方便的实现节点的插入操作。

在JavaScript原生的DOM操作中,我们通常使用appendChild和insertBefore方法来实现插入操作,下面的具体的代码示例。

 <body>
<div>我是div标签1</div>
<div>我是div标签2</div>
<script>
//appendChild方法使用
//01 创建p标签
var oP = document.createElement("p");
oP.innerHTML = "我是p标签";
//02 获取页面中第一个div标签
var oDiv1 = document.getElementsByTagName("div")[0];
//03 使用appendChild方法添加
//把p标签插入到oDiv1标签内容的后面
oDiv1.appendChild(oP);
//insertBefore方法使用
var oDiv2 = document.getElementsByTagName("div")[1];
//把p标签插入到oDiv2标签内容的前面
oDiv2.insertBefore(oP,oDiv2.firstChild);
</script>
</body>

jQuery框架中为我们提供了四个方法来提供对应的功能,它们分别是:
[1]append方法:向每个匹配的元素内部追加内容。
[2]appendTo方法:把所有匹配的元素追加到另一个指定的元素集合中,和append方法相反。
[3]prepend方法:向每个匹配的元素内部前置内容。
[4]prependTo方法:把所有匹配的元素前置到另一个指定的元素集合中,和append方法相反。

插入方法的代码示例

 <!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<script src="jQuery框架/jquery-2.0.0.js"></script>
</head>
<body>
<div class="cur">我是div1</div>
<div>我是div2</div>
<div>我是div3</div>
<ul>
<li>我是第1个li</li>
<li>我是第2个li</li>
<li>我是第3个li</li>
<li>我是第4个li</li>
<li>我是第5个li</li>
</ul>
<button>按钮</button>
<script>
$(function () {
$("button").click(function () {
//appendTo:把页面中所有的li标签都插入到所有的div标签内容的后面
//$("li").appendTo($("div"));
//append:把页面中所有的div标签都插入到所有的li标签内容的后面
//$("li").append($("div"));
//prependTo:把页面中所有的li标签都插入到所有的div标签内容的前面
//$("li").prependTo($("div"));
//prepend:把页面中所有的div标签都插入到所有的li标签内容的前面
//$("li").prepend($("div"));
})
})
</script>
</body>
</html>

jQuery框架中还提供了多个外部插入内容的方法,它们分别是:
[1]after方法:在每个匹配的元素之后插入内容。
[2]before方法:在每个匹配的元素之前插入内容。
[3]insertAfter方法:把所有匹配的元素插入到另一个指定的元素集合的后面。
[4]insertBefore方法:把所有匹配的元素插入到另一个指定的元素集合的前面。

7.3 删除DOM节点

JavaScript原生的DOM操作中可以使用removeChild方法来删除指定的节点以及其包含的所有子节点,并返回这些删除的内容。

jQuery框架中定义了3个删除内容的方法:它们分别是remove()、empty()和detach()。

remove方法能够将匹配的元素从DOM中删除。
empty方法用来清空元素包含的内容,该方法没有参数。
detach方法能够将匹配的元素从DOM中分离出来。

注意

[1] 删除和清空是两个概念,清空操作执行后该标签还存在。

[2] detach方法和remove方法差不多,但detach方法能够保存所有jQuery数据与被移走的元素相关联,所有绑定在元素上的事件、附加的数据等都会保存下来。如果您在移走一个元素不久后,又需要将该元素重新插入DOM,那么推荐使用detach方法。

7.4 复制和替换DOM节点

① 节点的复制

在JavaScript原生方式操作DOM节点时,可以使用cloneNode方法来复制节点,具体的语法如下:

语法:nodeObject.cloneNode(include_all)
参数:

include_all参数本身为布尔类型的值。

  • 如果为true,那么将会复制原有的节点以及所有的子节点。
  • 如果为false,那么紧紧复制节点本身。

jQuery框架中,使用clones方法来复制节点,具体的语法如下:

语法:jQ.clone([widthDataAndEvents],[deepWithDataAndEvents])
参数:
clone方法的两个参数都是可选的布尔值,如果不传递则默认全部为false。

  • widthDataAndEvents参数表示是否复制该节点的事件处理数据。
  • deepWithDataAndEvents参数表示是否复制子元素的事件处理数据。

② 节点的替换

在原生的DOM操作中,可以使用replaceChild方法来替换节点。
语法:nodeObject.replaceChild(new_node,old_node)
参数说明:new_node为指定的新节点,old_node为被替换的节点。如果替换成功,那么会返回被替换的节点,如果替换失败,那么会返回null。

jQuery框架中定义了replaceWith和replaceAll方法来替换节点。

[1] replaceWith方法

语法:jQ.replaceWith(newContent)
说明:replaceWith方法能够将所有匹配的元素都替换成指定的HTML或者是DOM元素。
示例:$("p").replaceWith("<div>我是DIV标签<div>")

[2] replaceAll方法

语法:jQ.replaceAll(selector)
说明:replaceAll方法和replaceWith是一对相反的操作。

jQuery系列 第七章 jQuery框架DOM操作的更多相关文章

  1. jQuery系列 第四章 jQuery框架的选择器

    第四章 jQuery框架的选择器 4.1 jQuery选择器说明 jQuery 最核心的组成部分就是选择器引擎.它完全继承了 CSS 的风格,可以对 DOM 元 素的标签名.属性名.状态等进行快速准确 ...

  2. jQuery系列 第六章 jQuery框架事件处理

    第六章 jQuery框架事件处理 JavaScript以事件驱动来实现页面的交互,其核心是以消息为基础,以事件来驱动.虽然利用传统的JavaScript事件处理方式也能够完成页面交互,但jQuery框 ...

  3. jQuery系列 第五章 jQuery框架动画特效

    第五章 jQuery框架动画特效 5.1 jQuery动画特效说明 jQuery框架中为我们封装了众多的动画和特效方法,只需要调用对应的动画方法传递合适的参数,就能够方便的实现一些炫酷的效果,而且jQ ...

  4. jQuery系列 第三章 jQuery框架操作CSS

    第三章 jQuery框架操作CSS 3.1 jQuery框架的CSS方法 jQuery框架提供了css方法,我们通过调用该方法传递对应的参数,可以方便的来批量设置标签的CSS样式. 使用JavaScr ...

  5. jquery系列教程7-自定义jquery插件全解:对象函数、全局函数、选择器

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  6. jQuery原生框架-----------------dom操作

    // 扩展DOM操作方法jQuery.fn.extend({ // 设置或者获取元素的内容 html: function( html ) { /* * 实现思路: * 1.不传参,返回第一个元素的内容 ...

  7. JQuery制作网页—— 第七章 jQuery中的事件与动画

    1. jQuery中的事件: ●和WinForm一样,在网页中的交互也是需要事件来实现的,例如tab切换效果,可以通过鼠标单击事件来实现 ●jQuery事件是对JavaScript事件的封装,常用事件 ...

  8. jQuery简单介绍及基本用法(选择器&DOM操作)

    简介 jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架).jQuery设计的宗旨是“write Le ...

  9. jQuery学习之路(2)-DOM操作

    ▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...

随机推荐

  1. ListView动态刷新adapter.notifyDataSetChanged()无反应

    前段时间在做一个动态刷新ListView(模拟聊天),遇到一个问题,调用notifyDataSetChanged()方法,数据源已经存在但是并没有动态刷新! 首先我们需要了解notifyDataSet ...

  2. wpf研究之道-datagrid控件(1)

    "想要说些什么 又不知从何说起",每当想要写一些关于wpf的文章,总是沉思良久,怕自己写不好.今天我想要说的是wpf中datagrid控件.我们先来看看它在整个类的层次结构:   ...

  3. 工作流Activiti5.13学习笔记(一)

    了解工作流 1.工作流(Workflow),就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档.信息或任务的过程自动进行,从而实现某 ...

  4. (译文)学习ES6非常棒的特性-字符串常量基础

    字符串常量基础 在ES2015之前我们是这么拼接字符串的: var result = 10; var prefix = "the first double digit number I le ...

  5. 冲刺NO.5

    Alpha冲刺第五天 站立式会议 项目进展 今日项目完成内容主要包括了JS的学习,事务管理员模块与学生模块的完善与补充,并且开始编写信用信息管理模块和奖惩事务管理模块. 问题困难 前端部分的技术掌握的 ...

  6. 201621123044 《Java程序设计》第六周实验总结

    1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图或相关笔记,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰 ...

  7. scrapy 模拟登陆

    import scrapy import urllib.request from scrapy.http import Request,FormRequest class LoginspdSpider ...

  8. [Android FrameWork 6.0源码学习] View的重绘ViewRootImpl的setView方法

    博客首页:http://www.cnblogs.com/kezhuang/p/ 本篇文章来分析一下WindowManager的后续工作,也就是ViewRootImpl的setView函数的工作 /i* ...

  9. MySQL InnoDB锁机制

    概述: 锁机制在程序中是最常用的机制之一,当一个程序需要多线程并行访问同一资源时,为了避免一致性问题,通常采用锁机制来处理.在数据库的操作中也有相同的问题,当两个线程同时对一条数据进行操作,为了保证数 ...

  10. JS实现页面内跳转

    使用js($.ajax中)实现页面内跳转(即:描点平滑跳转)的方法(aa为跳转目的标签的id): 在网络上有很多资料所说的:animate方法我试了并不好使,不知道是啥原因,欢迎大家指正,附上网络方法 ...