jQuery 中的 DOM 操作


Posted in Javascript onApril 26, 2016

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 相关文章推荐
javascript调试之DOM断点调试法使用技巧分享
Apr 15 Javascript
js实现键盘操作实现div的移动或改变的原理及代码
Jun 23 Javascript
JavaScript中的document.referrer在各种浏览器测试结果
Jul 18 Javascript
浅谈JavaScript Array对象
Dec 29 Javascript
AngularJS实用开发技巧(推荐)
Jul 13 Javascript
微信小程序 数据绑定详解及实例
Oct 25 Javascript
Vue.js 2.0学习教程之从基础到组件详解
Apr 24 Javascript
详解JavaScript 中 if / if...else...替换方式
Jul 15 Javascript
Vue2 添加数据可视化支持的方法步骤
Jan 02 Javascript
layui 富文本编辑器和textarea值的相互传递方法
Sep 18 Javascript
详解如何在JS代码中消灭for循环
Dec 11 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
Jul 26 Javascript
Bootstrap每天必学之弹出框(Popover)插件
Apr 25 #Javascript
基于JS实现EOS隐藏错误提示层代码
Apr 25 #Javascript
Bootstrap每天必学之按钮(Button)插件
Apr 25 #Javascript
第一章之初识Bootstrap
Apr 25 #Javascript
第二章之Bootstrap 页面排版样式
Apr 25 #Javascript
第三章之Bootstrap 表格与按钮功能
Apr 25 #Javascript
原生JS实现旋转木马式图片轮播插件
Apr 25 #Javascript
You might like
PHP批量生成缩略图的代码
2008/07/19 PHP
php实现统计目录文件大小的函数
2015/12/25 PHP
javascript中关于执行环境的杂谈
2011/08/14 Javascript
js中的referrer返回上一页使用介绍
2013/09/26 Javascript
Dojo Javascript 编程规范 规范自己的JavaScript书写
2014/10/26 Javascript
轻松创建nodejs服务器(2):nodejs服务器的构成分析
2014/12/18 NodeJs
Javascript的闭包详解
2014/12/26 Javascript
使用nodejs开发cli项目实例
2015/06/03 NodeJs
超简单的Vue.js环境搭建教程
2017/03/17 Javascript
NodeJS、NPM安装配置步骤(windows版本) 以及环境变量详解
2017/05/13 NodeJs
使用原生js写ajax实例(推荐)
2017/05/31 Javascript
vue项目中锚点定位替代方式
2019/11/13 Javascript
ElementUI中el-tree节点的操作的实现
2020/02/27 Javascript
[57:18]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#3VP VS VG
2016/03/03 DOTA
[03:53]2016国际邀请赛中国区预选赛第三日TOP10精彩集锦
2016/06/29 DOTA
[02:37]TI8勇士令状不朽珍藏II视频展示
2018/06/23 DOTA
Python常用列表数据结构小结
2014/08/06 Python
python连接远程ftp服务器并列出目录下文件的方法
2015/04/01 Python
python实现JAVA源代码从ANSI到UTF-8的批量转换方法
2015/08/10 Python
Python实现的基于优先等级分配糖果问题算法示例
2018/04/25 Python
django_orm查询性能优化方法
2018/08/20 Python
pytorch使用tensorboardX进行loss可视化实例
2020/02/24 Python
JavaScript+Canvas实现自定义画板的示例代码
2019/05/13 HTML / CSS
Java方面的关于数组和继承的笔面试题
2015/09/18 面试题
如何利用cmp命令比较文件
2016/04/11 面试题
美德好少年主要事迹
2014/01/29 职场文书
公司聘任书模板
2014/03/29 职场文书
小学生我的梦想演讲稿
2014/08/21 职场文书
超市店庆活动方案
2014/08/31 职场文书
村长党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
不尊敬老师的检讨书
2014/12/21 职场文书
幸福终点站观后感
2015/06/04 职场文书
严以律己专题学习研讨会发言材料
2015/11/09 职场文书
2016年小学推普宣传周活动总结
2016/04/06 职场文书
Python爬虫之爬取哔哩哔哩热门视频排行榜
2021/04/28 Python
vue组件冲突之引用另一个组件出现组件不显示的问题
2022/04/13 Vue.js