jQuery 中DOM 操作详解


Posted in Javascript onJanuary 13, 2015

jQuery 中的 DOM 操作

DOM(Document Object Model—文档对象模型):一种与浏览器,平台, 语言无关的接口,使用该接口可以轻松地访问页面中所有的标准组件

DOM 操作的分类:

DOM Core: DOM Core 并不专属于 JavaScript, 任何一种支持 DOM的程序设计语言都可以使用它. 它的用途并非仅限于处理网页,也可以用来处理任何一种是用标记语言编写出来的文档, 例如: XML

HTML DOM: 使用 JavaScript和 DOM 为 HTML文件编写脚本时, 有许多专属于 HTML-DOM的属性

CSS-DOM:针对于 CSS操作, 在 JavaScript中, CSS-DOM 主要用于获取和设置 style对象的各种属性

查找节点

查找节点:

查找元素节点:通过 jQuery 选择器完成.

查找属性节点:查找到所需要的元素之后, 可以调用 jQuery对象的 attr() 方法来获取它的各种属性值

创建节点

创建节点: 使用 jQuery 的工厂函数 $(): $(html);会根据传入的 html 标记字符串创建一个 DOM对象, 并把这个 DOM对象包装成一个 jQuery 对象返回.

注意:

动态创建的新元素节点不会被自动添加到文档中,而是需要使用其他方法将其插入到文档中;

当创建单个元素时,需注意闭合标签和使用标准的 XHTML 格式.例如创建一个<p>元素,可以使用 $(“<p/>”) 或 $(“<p></p>”),但不能使用 $(“<p>”) 或 $(“<P>”)

创建文本节点就是在创建元素节点时直接把文本内容写出来;创建属性节点也是在创建元素节点时一起创建

插入节点(1)

动态创建 HTML元素并没有实际用处, 还需要将新创建的节点插入到文档中,即成为文档中某个节点的子节点

jQuery 中DOM 操作详解

插入节点(2)

jQuery 中DOM 操作详解

以上方法不但能将新创建的 DOM元素插入到文档中, 也能对原有的 DOM元素进行移动.

删除节点

remove(): 从 DOM中删除所有匹配的元素, 传入的参数用于根据 jQuery表达式来筛选元素. 当某个节点用 remove()方法删除后, 该节点所包含的所有后代节点将被同时删除.这个方法的返回值是一个指向已被删除的节点的引用.

empty(): 清空节点 ?清空元素中的所有后代节点(不包含属性节点).

复制节点

clone(): 克隆匹配的 DOM元素, 返回值为克隆后的副本.但此时复制的新节点不具有任何行为.

clone(true): 复制元素的同时也复制元素中的的事件

替换节点

replaceWith(): 将所有匹配的元素都替换为指定的 HTML 或 DOM元素

replaceAll(): 颠倒了的 replaceWith() 方法.

注意: 若在替换之前, 已经在元素上绑定了事件,替换后原先绑定的事件会与原先的元素一起消失

包裹节点

wrap(): 将指定节点用其他标记包裹起来.该方法对于需要在文档中插入额外的结构化标记非常有用, 而且不会破坏原始文档的语义.

wrapAll(): 将所有匹配的元素用一个元素来包裹.而 wrap() 方法是将所有的元素进行单独包裹.

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

属性操作

attr(): 获取属性和设置属性

当为该方法传递一个参数时,即为某元素的获取指定属性

当为该方法传递两个参数时,即为某元素设置指定属性的值

jQuery 中有很多方法都是一个函数实现获取和设置.如: attr(), html(), text(), val(), height(), width(), css()等.

removeAttr(): 删除指定元素的指定属性

设置和获取 HTML, 文本和值

读取和设置某个元素中的 HTML内容: html() . 该方法可以用于 XHTML,但不能用于 XML 文档

读取和设置某个元素中的文本内容: text().该方法既可以用于 XHTML 也可以用于 XML文档.

读取和设置某个元素中的值: val() ---该方法类似 JavaScript 中的 value属性. 对于文本框,下拉列表框, 单选框该方法可返回元素的值(多选框只能返回第一个值).如果为多选下拉列表框,则返回一个包含所有选择值的数组

Javascript 相关文章推荐
jquery(live)中File input的change方法只起一次作用的解决办法
Oct 21 Javascript
Javascript 垃圾收集机制介绍理解
May 14 Javascript
jQuery的:parent选择器定义和用法
Jul 01 Javascript
javascript面向对象快速入门实例
Jan 13 Javascript
JavaScript学习笔记之DOM基础 2.4
Aug 14 Javascript
Angular使用$http.jsonp发送跨站请求的方法
Mar 16 Javascript
全面解析Node.js 8 重要功能和修复
Jun 02 Javascript
jQuery实现base64前台加密解密功能详解
Aug 29 jQuery
React Native 图片查看组件的方法
Mar 01 Javascript
vue中使用element ui的弹窗与echarts之间的问题详解
Oct 25 Javascript
vue+webpack 更换主题N种方案优劣分析
Oct 28 Javascript
JavaScript严格模式不支持八进制的问题讲解
Nov 07 Javascript
JavaScript常用的返回,自动跳转,刷新,关闭语句汇总
Jan 13 #Javascript
jQuery过滤选择器详解
Jan 13 #Javascript
jQuery入门介绍之基础知识
Jan 13 #Javascript
javascript实现时间格式输出FormatDate函数
Jan 13 #Javascript
Web表单提交之disabled问题js解决方法
Jan 13 #Javascript
JQuery控制div外点击隐藏而div内点击不会隐藏的方法
Jan 13 #Javascript
scrollWidth,clientWidth,offsetWidth的区别
Jan 13 #Javascript
You might like
常用的php ADODB使用方法集锦
2008/03/25 PHP
PHP运行时强制显示出错信息的代码
2011/04/20 PHP
php中防止恶意刷新页面的代码小结
2012/10/31 PHP
PHP实现的博客欢迎提示功能(很特别哦)
2014/06/05 PHP
php从数组中随机选择若干不重复元素的方法
2015/03/14 PHP
yii2中使用Active Record模式的方法
2016/01/09 PHP
JavaScript 学习笔记(十三)Dom创建表格
2010/01/21 Javascript
js实现的跟随鼠标移动的时钟效果(中英文日期显示)
2011/01/17 Javascript
浅析Cookie中的Path与domain
2013/12/18 Javascript
JS获取屏幕高度的简单实现代码
2016/05/24 Javascript
jquery动态遍历Json对象的属性和值的方法
2016/07/27 Javascript
AngularJS入门教程一:路由用法初探
2017/05/27 Javascript
AngularJS入门教程二:在路由中传递参数的方法分析
2017/05/27 Javascript
纯js实现的积木(div层)拖动功能示例
2017/07/19 Javascript
springMvc 前端用json的方式向后台传递对象数组方法
2018/08/07 Javascript
jquery.pagination.js分页使用教程
2018/10/23 jQuery
Vue通过getAction的finally来最大程度避免影响主数据呈现问题
2020/04/24 Javascript
vue中element 的upload组件发送请求给后端操作
2020/09/07 Javascript
使用原生javascript开发计算器实例代码
2021/02/21 Javascript
python连接MySQL数据库实例分析
2015/05/12 Python
python开发之IDEL(Python GUI)的使用方法图文详解
2015/11/12 Python
详解Python中 __get__和__getattr__和__getattribute__的区别
2016/06/16 Python
python实现朴素贝叶斯算法
2018/11/19 Python
在pycharm 中添加运行参数的操作方法
2019/01/19 Python
Flask框架实现的前端RSA加密与后端Python解密功能详解
2019/08/13 Python
python重要函数eval多种用法解析
2020/01/14 Python
Python操作MongoDb数据库流程详解
2020/03/05 Python
浅谈numpy中函数resize与reshape,ravel与flatten的区别
2020/06/18 Python
python实现人性化显示金额数字实例详解
2020/09/25 Python
让ie浏览器成为支持html5的浏览器的解决方法(使用html5shiv)
2014/04/08 HTML / CSS
美国知名的摄影器材销售网站:Adorama
2017/02/01 全球购物
J2EE的优越性主要表现在哪些方面
2016/03/28 面试题
初三毕业评语
2014/12/26 职场文书
2015年机关党建工作总结
2015/05/22 职场文书
白银帝国观后感
2015/06/17 职场文书
SQL中的三种去重方法小结
2021/11/01 SQL Server