jQuery系列 第七章 jQuery框架DOM操作
第七章 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是一对相反的操作。
- Posted by 博客园·文顶顶 ~ 文顶顶的个人博客_花田半亩
- 联系作者 简书·文顶顶 新浪微博·文顶顶
- 原创文章,版权声明:自由转载-非商用-非衍生-保持署名 | 文顶顶
jQuery系列 第七章 jQuery框架DOM操作的更多相关文章
- jQuery系列 第四章 jQuery框架的选择器
第四章 jQuery框架的选择器 4.1 jQuery选择器说明 jQuery 最核心的组成部分就是选择器引擎.它完全继承了 CSS 的风格,可以对 DOM 元 素的标签名.属性名.状态等进行快速准确 ...
- jQuery系列 第六章 jQuery框架事件处理
第六章 jQuery框架事件处理 JavaScript以事件驱动来实现页面的交互,其核心是以消息为基础,以事件来驱动.虽然利用传统的JavaScript事件处理方式也能够完成页面交互,但jQuery框 ...
- jQuery系列 第五章 jQuery框架动画特效
第五章 jQuery框架动画特效 5.1 jQuery动画特效说明 jQuery框架中为我们封装了众多的动画和特效方法,只需要调用对应的动画方法传递合适的参数,就能够方便的实现一些炫酷的效果,而且jQ ...
- jQuery系列 第三章 jQuery框架操作CSS
第三章 jQuery框架操作CSS 3.1 jQuery框架的CSS方法 jQuery框架提供了css方法,我们通过调用该方法传递对应的参数,可以方便的来批量设置标签的CSS样式. 使用JavaScr ...
- jquery系列教程7-自定义jquery插件全解:对象函数、全局函数、选择器
点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...
- jQuery原生框架-----------------dom操作
// 扩展DOM操作方法jQuery.fn.extend({ // 设置或者获取元素的内容 html: function( html ) { /* * 实现思路: * 1.不传参,返回第一个元素的内容 ...
- JQuery制作网页—— 第七章 jQuery中的事件与动画
1. jQuery中的事件: ●和WinForm一样,在网页中的交互也是需要事件来实现的,例如tab切换效果,可以通过鼠标单击事件来实现 ●jQuery事件是对JavaScript事件的封装,常用事件 ...
- jQuery简单介绍及基本用法(选择器&DOM操作)
简介 jQuery是一个快速.简洁的JavaScript框架,是继Prototype之后又一个优秀的JavaScript代码库(或JavaScript框架).jQuery设计的宗旨是“write Le ...
- jQuery学习之路(2)-DOM操作
▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...
随机推荐
- NodeJS FTP模块使用
模块说明:https://www.npmjs.com/package/ftp 上传文件 建立连接-> 判断文件夹是否存在->创建文件夹->上传文件->End 核心代码: 连接参 ...
- 20.C++- "&&","||"逻辑重载操作符的缺陷、","逗号重载操作符的分析
"&&","||"逻辑重载操作符的缺陷 大家,都知道"&&","||"拥有"短 ...
- jQuery学习笔记 .addClass()/.removeClass()简单学习
使用jQuery或javaScript来动态改变页面中某个或部分元素的样式,为了实现这样的功能,我们往往都是使用jQuery或javaScript来控制HTML中DOM的类名(class)从而实现增加 ...
- python爬虫---抓取优酷的电影
最近在学习爬虫,用的BeautifulSoup4这个库,设想是把优酷上面的电影的名字及链接爬到,然后存到一个文本文档中.比较简单的需求,第一次写爬虫.贴上代码供参考: # coding:utf-8 i ...
- JavaWeb学习笔记二 Http协议和Tomcat服务器
Http协议 HTTP,超文本传输协议(HyperText Transfer Protocol),是互联网上应用最为广泛的一种网络协议.所有的WWW文件都必须遵守这个标准.设计HTTP最初的目的是为 ...
- hibernate框架学习笔记5:缓存
缓存不止存在与程序中,电脑硬件乃至于生活中都存在缓存 目的:提高效率 比如IO流读写字节,如果没有缓存,读一字节写一字节,效率低下 hibernate中的一级缓存:提高操作数据库的效率 示例: 抽取的 ...
- C语言博客作业--字符数组-陈张鑫
一.PTA实验作业(4分) 题目1:7-5 查验身份证 1. 本题PTA提交列表(要提交列表,不是结果) 2. 设计思路(伪代码或流程图) 定义变量身份证个数n,合法个数count=0,flag=0, ...
- idea搭建springdata+mongodb+maven+springmvc
idea搭建springdata+mongodb+maven+springmvc 今天我们来学习一下SpringData操作MongoDB. 项目环境:IntelliJ IDEA2017+maven3 ...
- 开发者的如何优雅的使用OSX
Mac对于IT开发者来说是最好的开发工具,没有之一. 但是对于大部分人来说,第一个接触的PC操作系统都是Windows系统,此文将带大家优雅的快速学习和使用Mac的OSX系统. 1. 从键盘说起 Ma ...
- Django-rest-framework源码分析----权限
添加权限 (1)API/utils文件夹下新建premission.py文件,代码如下: message是当没有权限时,提示的信息 # utils/permission.py class SVIPPr ...