DOM
DOM:Document Object Model 文档对象模型
文档:html页面
文档对象:页面中的元素
文档对象模型:定义为了能够让程序(js)去操作页面中的元素
DOM会把文档看作是一棵树document > html > html(标签),同时定义了很多方法来操作这棵树中的没一个元素;
DOM节点:
操作子节点和兄弟节点:
childNodes(不推荐使用)是一个属性,属性是不需要加括号,用某个对象来调用,它是一个子节点列表集合。只包含一级子节点,不包含孙级节点
标准下元素节点包含文本节点,也包含非法嵌套标签
在非标准下不包含文本,不会包含非法嵌套标签
dom节点的类型有很多种 12种
nodeType
1、元素节点 2、属性节点 3、文本节点
nodeType:只读属性 当前元素的节点类型
attributes:只读属性 属性列表集合
children 是一个可读属性,返回一个子节点的列表
标准下:只包含元素类型
非标准下:只包含元素类型
firstChild 第一个子节点
标准下:会包含文本节点
非标准下:不包含文本节点
firstElementChild 第一个元素子节点
lastChild与firstChild一样
nextSibling 下一个元素节点
previousSibling 上一个元素节点
父节点操作
parentNode 当前节点的父级节点 没有什么兼容问题可以使用
offsetParent 与parentNode的区别 离当前元素有定位属性的的父节点,如果没有定位父级,默认是body
ie7以下,默认是html,如果某个元素出发了layout,那么offsetParent的父节点会指向触发layout的元素节点;
位置属性
offsetLeft/Top 只读属性 当前元素到定位父级的距离(偏移值)
style.width //样式宽
clientWidth //样式宽+padding 可视区宽度
offsetWidth //样式宽+padding+border 占位宽
元素的动态创建
document.creatElement("");//创建元素
父级.appendChild(); 追加元素
父级.insertBefore(新的元素,被插入的元素);//在指定元素前面插入元素
在ie下如果第二个参数节点不存在,会报错,在其他标准浏览器下如果第二个参数的节点不存在,会以appendChild的形式进行添加
父级.removeChild(); 移除节点元素 //有坑,这里批量删除的时候倒序删便可解决这个问题
父级.replaceChild(新节点,被替换的节点);
操作表格
tHead :表格头
tBodies :表格正文
tFoot :表格尾
rows :行
cells:列
table.tBodies[0] //获取第一个tbody节点 类似于getElementsByTagName获取的是一个元素节点的组合
table.tBodies[0].rows[0]//获取表格正文部分的第一行的tr节点
table.tBodies[0].rows[0].cells[0]//获取表格第一行第一列的单元格节点td节点
操作表单
//name
在表单中name比id更重要
通过form1表单点上name值就可以获取该元素了
form1.text1.onchange=function(){}
//当表单值发生改变时
//text当光标离开时值发生改变时发生的事
//radio:标准下点击时候只要值变了,就会发生事件,非标准下焦点离开的时候如果值变了就会触发
//
当类型为选项是radio,把两个input的name改成一样,那么就可以变成单选了,获取值的是一个集合,name[0]这样
表单事件onsubmit onreset
onsubmit 当提交表单的时候触发
onreset 重置表单
DOM的更多相关文章
- 关于DOM的操作以及性能优化问题-重绘重排
写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...
- 读书笔记:JavaScript DOM 编程艺术(第二版)
读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...
- 页面嵌入dom与被嵌入iframe的攻防
1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...
- 通俗易懂的来讲讲DOM
DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...
- HTML DOM 介绍
本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...
- HTML DOM 对象
本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...
- 重撸js_2_基础dom操作
1.node 方法 返回 含义 nodeName String 获取节点名称 nodeType Number 获取节点类型 nodeValue String 节点的值(注意:文本也是节点) 2.inn ...
- 虚拟dom与diff算法 分析
好文集合: 深入浅出React(四):虚拟DOM Diff算法解析 全面理解虚拟DOM,实现虚拟DOM
- 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?
引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...
- jQuery学习之路(2)-DOM操作
▓▓▓▓▓▓ 大致介绍 jQuery作为JavaScript库,继承并发扬了JavaScript对DOM对象操作的特性,使开发人员能方便的操作DOM对象. ▓▓▓▓▓▓ jQuery中的DOM操作 看 ...
随机推荐
- Android InputType详解
android:inputType 如果设置android:inputType = "number",则默认弹出的输入键盘为数字键盘,且输入的内容只能为数字. InputType文 ...
- gulp入门小记
由于我所在的项目组一直在用gulp构建工具,而我只是在前人搭好的环境下每次运行gulp packJs来打包js,对里面的东西全然不知,刚好最近有些时间就想自己从学学将gulp怎么用于构建前端项目中,这 ...
- C# List 排序各种用法与比较
下面介绍各种List的sort的用法与比较 首先,我们建一个People的实体,有name.age.sex的属性,我们要排序的字段是年龄age 新建一个实体类 public class People ...
- MySQL 导出数据
MySQL中你可以使用SELECT...INTO OUTFILE语句来简单的导出数据到文本文件上. 使用 SELECT ... INTO OUTFILE 语句导出数据 以下实例中我们将数据表 cnbl ...
- 3.raid基础应用
raid分为软备份和硬备份 软备份主要用来实验 应备份用于生产环境 raid0(带区卷) 具有很高的数据传输率,没有数据的冗余 1块磁盘 raid1(镜像卷) 提供数据冗余,利用率低 2块 ...
- WPF 自定义的窗口拖动
WPF原有的窗口样式太丑,当我们重新定义窗口时,则需要添加一些额外的功能,如拖动~ 1.在界面上对布局元素如Grid,添加委托事件: MouseLeftButtonDown="UIEleme ...
- java中的SPI机制
1 SPI机制简介 SPI的全名为Service Provider Interface.大多数开发人员可能不熟悉,因为这个是针对厂商或者插件的.在java.util.ServiceLoader的文档里 ...
- 烂泥:学习centos之快速搭建LNMP环境
本文由秀依林枫提供友情赞助,首发于烂泥行天下 以前在centos下安装软件都是喜欢源码安装,不过昨天因为一个事情需要一个centos 下的LNMP环境.反倒不会搞了,今天特意记录下,以备后续使用. 一 ...
- 【转】在CentOS6.5安装 svn1.8 (亲测可用)
from : http://tecadmin.net/install-subversion-1-8-on-centos-rhel/ How to Install Subversion (SVN) 1 ...
- Linux文本查看及处理.md
cat cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用. 主要功能 一次显示整个文件:cat ...