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的更多相关文章

  1. 关于DOM的操作以及性能优化问题-重绘重排

     写在前面: 大家都知道DOM的操作很昂贵. 然后贵在什么地方呢? 一.访问DOM元素 二.修改DOM引起的重绘重排 一.访问DOM 像书上的比喻:把DOM和JavaScript(这里指ECMScri ...

  2. 读书笔记:JavaScript DOM 编程艺术(第二版)

    读完还是能学到很多的基础知识,这里记录下,方便回顾与及时查阅. 内容也有自己的一些补充. JavaScript DOM 编程艺术(第二版) 1.JavaScript简史 JavaScript由Nets ...

  3. 页面嵌入dom与被嵌入iframe的攻防

    1.情景一:自己的页面被引入(嵌入)至别人的页面iframe中 if(window.self != window.top){ //url是自己页面的url window.top.location.hr ...

  4. 通俗易懂的来讲讲DOM

    DOM是所有前端开发每天打交道的东西,但是随着jQuery等库的出现,大大简化了DOM操作,导致大家慢慢的“遗忘”了它的本来面貌.不过,要想深入学习前端知识,对DOM的了解是不可或缺的,所以本文力图系 ...

  5. HTML DOM 介绍

    本篇主要介绍DOM内容.DOM 节点.节点属性以及获取HTML元素的方法. 目录 1. 介绍 DOM:介绍DOM,以及对DOM分类和功能的说明. 2. DOM 节点:介绍DOM节点分类和节点层次. 3 ...

  6. HTML DOM 对象

    本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...

  7. 重撸js_2_基础dom操作

    1.node 方法 返回 含义 nodeName String 获取节点名称 nodeType Number 获取节点类型 nodeValue String 节点的值(注意:文本也是节点) 2.inn ...

  8. 虚拟dom与diff算法 分析

    好文集合: 深入浅出React(四):虚拟DOM Diff算法解析 全面理解虚拟DOM,实现虚拟DOM

  9. 窥探Vue.js 2.0 - Virtual DOM到底是个什么鬼?

    引言 你可能听说在Vue.js 2.0已经发布,并且在其中新添加如了一些新功能.其中一个功能就是"Virtual DOM". Virtual DOM是什么 在之前,React和Em ...

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

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

随机推荐

  1. Android InputType详解

    android:inputType 如果设置android:inputType = "number",则默认弹出的输入键盘为数字键盘,且输入的内容只能为数字. InputType文 ...

  2. gulp入门小记

    由于我所在的项目组一直在用gulp构建工具,而我只是在前人搭好的环境下每次运行gulp packJs来打包js,对里面的东西全然不知,刚好最近有些时间就想自己从学学将gulp怎么用于构建前端项目中,这 ...

  3. C# List 排序各种用法与比较

    下面介绍各种List的sort的用法与比较 首先,我们建一个People的实体,有name.age.sex的属性,我们要排序的字段是年龄age 新建一个实体类 public class People ...

  4. MySQL 导出数据

    MySQL中你可以使用SELECT...INTO OUTFILE语句来简单的导出数据到文本文件上. 使用 SELECT ... INTO OUTFILE 语句导出数据 以下实例中我们将数据表 cnbl ...

  5. 3.raid基础应用

    raid分为软备份和硬备份 软备份主要用来实验 应备份用于生产环境 raid0(带区卷)    具有很高的数据传输率,没有数据的冗余  1块磁盘 raid1(镜像卷)  提供数据冗余,利用率低  2块 ...

  6. WPF 自定义的窗口拖动

    WPF原有的窗口样式太丑,当我们重新定义窗口时,则需要添加一些额外的功能,如拖动~ 1.在界面上对布局元素如Grid,添加委托事件: MouseLeftButtonDown="UIEleme ...

  7. java中的SPI机制

    1 SPI机制简介 SPI的全名为Service Provider Interface.大多数开发人员可能不熟悉,因为这个是针对厂商或者插件的.在java.util.ServiceLoader的文档里 ...

  8. 烂泥:学习centos之快速搭建LNMP环境

    本文由秀依林枫提供友情赞助,首发于烂泥行天下 以前在centos下安装软件都是喜欢源码安装,不过昨天因为一个事情需要一个centos 下的LNMP环境.反倒不会搞了,今天特意记录下,以备后续使用. 一 ...

  9. 【转】在CentOS6.5安装 svn1.8 (亲测可用)

    from :  http://tecadmin.net/install-subversion-1-8-on-centos-rhel/ How to Install Subversion (SVN) 1 ...

  10. Linux文本查看及处理.md

    cat cat命令的用途是连接文件或标准输入并打印.这个命令常用来显示文件内容,或者将几个文件连接起来显示,或者从标准输入读取内容并显示,它常与重定向符号配合使用. 主要功能 一次显示整个文件:cat ...