JavaScipt中对DOM的理解
一.理解DOM
浏览器通过文档对象模型DOM使JavaScript程序可以访问页面上的元素,而DOM是页面上XHTML中文档正文标题、段落、列表、样式ID、class以及所有其他出现的数据的一个内部表示。
DOM的主要思想是HTML上每一个元素分别对应于DOM中的一个节点。DOM定义了许多种节点类型来表示节点的多个方面:
1.文档节点Document-----最顶层的节点或者说是各节点,它代表整个XHTML文档,所有的其他节点都是附属于它的。
2.文档类型节点DocumentType------DTD引用(使用<!DOCTYPE >语法)的对象表现形式。
3.文档片段节点DocumentFragment-----可以像Document一样来保存其他节点。
4.元素节点Element-----表示起始标记和结束标记之间的内容。
5.文本节点Text----代表XHTM文档中元素的起始标记和结束标记之间,或者CDataSection内容包含普通文本。
6.属性节点Attr-----d代表元素节点开始标记内指定的属性。
7.CDataSection节点----<![CDATA]>的对象表现形式。
8.注释节点Comment----代表注释。
二.使用DOM
1.访问相关的节点
要访问<html/>元素,我们可以使用document的documentElement特性:
Var oHead=oHtml.firstChild;
Var oBody=oHtml.lastChild;
也可以使用childNodes特性来完成同样的工作,使用方括号标记:
Var oHead=oHtml.childNodes[0];
Var oHead=oHtml.childNodes[1];
实际上,正式的从childNodes列表中获取子节点的方法是使用item()方法:
Var oHead=oHtml.childNodes.item(0);
Var oHead=oHtml.childNodes.item(0);
2.检测节点类型
元素节点的attributes属性其实是NameNodeMap,它提供一些用于访问和处理其内容的方法,包括:
(1).getNameItem(name)---返回nodeName属性值等于name的节点
(2).removeNameItem(name)----删除nodeName属性值等于name的节点
(3).setNameItme(node)----将node添加到列表中,按其 nodeName属性进行索引
(4).itme(pose)----像NodeList一样,返回在位置pos的节点
3.访问指定节点
(1).getElementByTagName()方法
DOM定义了getElementByTagName()方法,用来返回一个包含所有的tagName(标记名)特性等于某个指定值得元素的NodeList。如:
Var oImgs=document.getElementsByTagName(“img”);
上一行代码返回文档中所有<img/>元素的列表。
(2).getElementByName()方法
DOM定义了getElementByName()方法,用来获取所有name属性等于指定值得元素,如:
Var oRadios=document.getElementByName”radColor”);
(3).getElementById()方法
Var=oDiv=document.getElementById(“div1”);
4.创建和操作节点
(1) 创建节点createElement( )、createTextNode( )、appendChild( ) 如:
先创建节点名称
Var op=document.createElement(“p”);
再创建text文本节点
Var text=document.createTextNode;
把text值加到p元素中
Op.appendChild(text);
把元素加到页面上
Document.Body appendChild(op);
(2)删除、替换节点removeChild( )、replaceChild( )、insertBefore( )
删除节点
Var op=document.body.getElementByName(“p”)[0]
Op.parentNode.removeChild(op)
替换节点
Var newp=document.createElement(“p”)
Var text=document.createTextNode
Newp.appendChild(text);
Var oldp=document.getElementByName(“p”)[0];
Oldp.parentNode.replaceChild(newP,oldP);
5.操作文本节点
AppenData(string)将字符添加在文本节点尾部
DeleteData(offset,count)删除文本节点中从指定位置开始的指定数量的字符
InsertData(offset,string)将指定字符添加到指定位置
ReplaceData(offset,count,string)用给的字符串替换文本节点指定位置数量的文本数
Splittext(offset)将文本分为两个部分右边返回为新节点,左边留在原始位置
SubstringData(offset,count)从文本节点中数据返回指定位置指定数目的字符串
三.HTML DOM特征功能
1.table方法
使用DOM来创建HTML 表格
var table=document.creatElement(“table”)
var tbody=createElement(“tbody”);
table.appendChild(tbody)
var otr1= document.creatElement(“tr”);
tbody. appendChild(otr1)
var otd1= document.creatElement(“td”);
otd1. appendChild(document.creatTextNode(“Cell 1,1”));
otr1. appendChild(otd1);
四.innerHTML
将HTML的字符串赋值给一个元素
代码<div><b>hello</b>WORLD</div> innerHTML <b>hello</b>WORLD
JavaScipt中对DOM的理解的更多相关文章
- javascipt中的DOM对象
1.HTML中DOM对象的概念 HTML Document Object Model(文档对象模型) HTML DOM定义了访问和操作HTML文档的标准方法 HTML DOM把HTML文档呈现为带有元 ...
- jQuery中的DOM操作总结
jQuery中的DOM操作 DOM是Document Object Medel的缩写,它的意思是文档对象模型,根据W3C的官方说法,DOM是一种跟浏览器,平台以及语言都没有关系的一种规范,也就是一种接 ...
- html5中的dom中的各种节点的层次关系是怎样的
html5中的dom中的各种节点的层次关系是怎样的 一.总结 一句话总结:Node节点是所有节点的基类,所以都继承它的方法 1.dom提供在js中动态修改html标签的作用 比如增加修改标签等,并且是 ...
- Vue中diff算法的理解
Vue中diff算法的理解 diff算法用来计算出Virtual DOM中改变的部分,然后针对该部分进行DOM操作,而不用重新渲染整个页面,渲染整个DOM结构的过程中开销是很大的,需要浏览器对DOM结 ...
- DOM的理解
https://www.cnblogs.com/djtang/p/11538420.html dom的理解 https://blog.csdn.net/jiuqiyuliang/article/de ...
- React中diff算法的理解
React中diff算法的理解 diff算法用来计算出Virtual DOM中改变的部分,然后针对该部分进行DOM操作,而不用重新渲染整个页面,渲染整个DOM结构的过程中开销是很大的,需要浏览器对DO ...
- 借助JavaScript中的Dom属性改变Html中Table边框的颜色
借助JavaScript中的Dom属性改变Html中Table边框的颜色 -------------------- <html> <head> <title>我是页 ...
- 【Java EE 学习 32 下】【JQuery】【JQuey中的DOM操作】
一.JQuery中的DOM操作. 什么是DOM:DOM是一中和浏览器.平台.语言无关的接口,使用该接口可以轻松访问页面中所有的标准组件.DOM简称文档对象模型,是Document Oject Mode ...
- javascript 获取iframe中的dom
太扯了,一个多小时都没搞定,获取不到iframe中的dom元素. <div id="one"> this is one </div> <div> ...
随机推荐
- NSIS:使用PassDialog插件实现密码安装(卸载)功能
原文 NSIS:使用PassDialog插件实现密码安装(卸载)功能 有时,出于特殊的需求,我们要给安装或卸载程序加一个密码,只有输入了正确的密码才可以继续.比如: 下面我们使用插件来实现安装密码: ...
- 如何关闭CBox(2.4版本号)强制升级的形式
从今天开始2.4.0.9版本号CBox,提示检测到新的版本号,能够使用后必须更新为新版本号,提示表见下面的例子. 此次升级是强制升级.假如你选择不升级(单击窗体上的升级提示右下角"辍学but ...
- python抓取网络内容
最近想做研究互联网来获取数据,只是有一点python,让我们来看一个比较简单的实现. 例如,我想抓住奥巴马的每周演讲http://www.putclub.com/html/radio/VOA/pres ...
- hdu 1542 Atlantis 段树区,并寻求,,,尼玛真坑人数据,不要打开一小阵!
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total S ...
- Nyoj 一笔画问题(图论)
描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来. 规定,所有的边都只能画一次,不能重复画. 输入 第一行只有一个正整数N(N&l ...
- poj1251--Kruskal
/* * poj1251-- Kruskal * date 2014/7/15 * state AC */ #include <iostream> #include <algorit ...
- sql server判断表是否存在
1.判断数据表是否存在 方法一: use yourdb;go if object_id(N'tablename',N'U') is not nullprint '存在'else print '不存在' ...
- jquery中DOM的操作方法
先介绍几个比较简单的方法,不经常用到,做个记录 1. filter() 方法 顾名思义,filter是一个过滤器,如果给定表示 DOM 元素集合的 jQuery 对象,.filter() 方法会用匹配 ...
- 关于启动调试时,总是启动多个web端口的问题
在一个解决方案中,经常包含多个web项目,当设置某一个web项目为起始项目后,启动调试,会发现其他的web项目的端口也会一起打开,显示在电脑的右下方,其实开启其他端口有时是没必要的,只是多占用了系统内 ...
- java_windows下修改eclipse的默认编码
windows下修改eclipse的默认编码 windows下一般系统编码为 GB2312(中文版的windows), 由于我比较喜欢utf8格式的编码,现将修改方式和大家分享 如果要使新建立工程 ...