1.创建新的HTML元素:appendChild();

如需向HTML DOM添加元素,首先必须创建该元素,然后把它追加到已有的元素上;

<div id="div1">

<p id="p1">This is a paragraph.</p>

<p id="p2">This is another paragraph.</p>

</div>

<script>

var para=document.createElement("p");        //创建一个新的<p>元素

var node=document.createTextNode("This is new.");          //首先创建一个文本节点

para.appendChild(node);            //向<p>元素追加文本节点

var element=document.getElementById("div1");          //向查找到一个已有元素

element.appendChild(para);             //向这个已存在的元素追加新元素

</script>

2.创建新的HTML元素:insertBefore()方法;

<div id="div1">

<p id="p1">This is a paragraph.</p>

<p id="p2">This is another paragraph.</p>

</div>

<script>

var para=document.createElement("p");

var node=document.createTextNode("This is new.");

para.appendChild(node);

var element=document.getElementById("div1");

var child=document.getElementById("p1");

element.insertBefore(para,child);

</script>

3.删除已有的HTML元素:如需删除HTML元素,您必须清楚该元素的父元素

<div id="div1">

<p id="p1">This is a paragraph.</p>

<p id="p2">This is another paragraph.</p>

</div>

<script>

var parent=document.getElementById("div1");

var child=document.getElementById("p1");

parent.removeChild(child);     //从父元素中删除子元素

</script>

可以不查找父元素直接删除子元素的常用方法:

var child=document.getElementById("p1");

child.parentNode.removeChild(child);

4.替换HTML元素:如需替换HTML DOM中的元素,请使用replaceChild()方法:

<div id="div1">

<p id="p1">This is a paragraph.</p>

<p id="p2">This is another paragraph.</p>

</div>

<script>

var para=document.createElement("p");

var node=document.createTextNode("This is new .");

para.appendChild(node);

var parent=document.getElementById("div1");

var child=document.getElementById("p1");

parent.replaceChild(para,child);

</script>

5.HTML DOM-事件

**对事件作出反应:如需在用户点击某个元素时执行代码,请把JavaScript代码添加到HTML事件属性中:

<!DOCTYPE html>

<html>

<body>

<h1 onclick="this.innerHTML='Ooops!'">Chick on this text!</h1>

</body>

</html>

**HTML事件属性:如需向HTML元素分配事件,您可以使用事件属性:

<button onclick="displayDate()">Try it</button>

**使用HTML DOM来分配事件:

<script>

document.getElementById("myBtn").onclick=function(){displayDate()};

</script>

**onload和onunload事件

onload事件可用于检查访客的浏览器类型和版本,以便于基于这些信息加载不同版本的网页

onload和onunload事件可用于处理cookies

<body onload="checkCookies()">

**onchange事件:onchange事件常用于输入字段的验证

<input type="text" id="fname" onchange="upperCase()">

**onmouseover和onmouseout事件:用于在鼠标指针移动到或离开元素时触发函数

**onmousedown,onmouseup以及onclick事件:

onmousedown,onmouseup以及onclick事件是鼠标点击的全部过程,首先当鼠标被点击时,触发onmousedown事件,然后,当鼠标被松开时,会触发onmouseup事件,最后,当鼠标点击完成时,触发onclick事件;

6.HTML DOM导航:通过HTML DOM,能够使用节点关系在节点树中导航

**HTML DOM节点列表

var x=document.getElementsByTagName("p");   //选取文档中所有<p>节点

y=x[1];         //通过下标号访问这些节点,访问第二个<p>

**HTML DOM节点列表长度:length属性定义节点列表中节点的数量,可以使用length属性来循环节点列表:

x=document.getElementsByTagName("p");

for(i=0;i<x.length;i++){

document.write(x[i].innerHTML);

document.write("<br />")

}

**能够使用三个节点属性:parentNode,firstChild以及lastChild,在文档结构中进行导航

<html>

<body>                                            //<body>元素是首个<p>元素和<div>元素的父节点(parentNode)

<p id="intro">Hello World!</p>            //首个<p>元素是<body>元素的首个子元素(firstChild)

<div>                                               //<div>元素是<body>元素的最后一个子元素(lastChild)

  <p>The DOM is very useful!</p>

  <p>This example demonstrates node relationships.</p>

<script>

x=document.getElementById("intro");

document.write(x.firstChild.nodeValue);

</script>

</div>

</body>

</html>

**DOM根节点:这里有两个特殊的属性,可以访问全部文档:

document.documentElement-全部文档

document.body-文档主体

<html>

<body>

<p>Hello World!</p>

<div>

  <p>The DOM is very useful!</p>

  <p>This  example demonstrates the <b>document.body</b>property</p>

</div>

<script>

alert(document.body.innerHTML);

</script>

</body>

</html>

**ChildNodes和nodeValue:除了innerHTML属性,也可以使用childNodes和nodeValue属性来获取元素的内容;

<html>

<body>

<p id="intro">Hello World!</p>

<script>

var txt=document.getElementById("intro").childNodes[0].nodeValue;

document.write(txt);

</script>

</body>

</html>

HTML DOM学习之三的更多相关文章

  1. AspectJ基础学习之三HelloWorld(转载)

    AspectJ基础学习之三HelloWorld(转载) 一.创建项目 我们将project命名为:aspectjDemo.然后我们新建2个package:com.aspectj.demo.aspect ...

  2. Linux学习之三-Linux系统的一些重要配置文件

    Linux学习之三-Linux系统的一些重要配置文件 1.网卡配置文件 /etc/sysconfig/network-scripts/ifcfg-eth0 说明: DEVICE=eth0        ...

  3. C++11并发学习之三:线程同步(转载)

    C++11并发学习之三:线程同步 1.<mutex> 头文件介绍 Mutex又称互斥量,C++ 11中与 Mutex 相关的类(包括锁类型)和函数都声明在 <mutex> 头文 ...

  4. 前端基础-BOM和DOM学习

    JavaScript分为 ECMAScript,BOM,DOM. BOM:是指浏览器对象模型,使JavaScript有能力与浏览器进行对象. DOM:是指文档对象模型,通过它,可以访问HTML文档的所 ...

  5. HTML DOM 学习

    HTML DOM 学习 By: Mirror王宇阳 E-mail:2821319009@qq.com 博客主页:https://www.cnblogs.com/wangyuyang1016/ DOM ...

  6. jackson学习之三:常用API操作

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  7. JavaScript DOM学习总结(一)

    DOM 什么是DOM?简单地说DOM是一套对文档内容进行抽象和概念化的方法.   W3C给出的DOM定义是这样的:"一个与系统平台和编程语言无关的接口,程序和脚本以通过这个接口动态的访问和修 ...

  8. Js dom 学习

    节点类型 文档节点: 一棵DOM树的顶端是文档节点,它呈现为整个页面(相当于document对象),当需要访问任何元素.属性或文本节点时,都需要通过文档节点来进行导航.(document.) 元素节点 ...

  9. TCP学习之三:客户端、服务端同步传输字符串

    参考学习张子阳大神的博客:http://www.cnblogs.com/JimmyZhang/category/101698.html 一个客户端.发送一条消息 客户端: 服务端: 注意:Networ ...

随机推荐

  1. 关于js事件委托

    由于事件处理程序可以为现代 Web 应用程序提供交互能力,因此许多开发人员会不分青红皂白地 向页面中添加大量的处理程序. 在创建 GUI 的语言(如 C#)中,为 GUI 中的每个按钮添加一个 onc ...

  2. 51 NOD 1384 全排列(STL 搜索)

    1384 全排列       基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题        收藏        关注   给出一个字符串S(可能又重复的字符),按照字典序 ...

  3. JS练习题

    1.带参数的函数不能重复调用 2.顺序语句: 3.在重复调用中打断 调用用 return   例如: Interval 时间间隔   先清一下  再接着 return:其他的调用也可以加return打 ...

  4. springmvc 文件下传、上载、预览。以二进制形式存放到数据库(转载)

    springmvc 文件上传.下载.预览.以二进制形式存放到数据库.数据库中的关于传入附件的字段我写了2个:一个存放内容accessory,一个存放文件的后缀filetype 上传:首先需要2个必须的 ...

  5. 后台弹出JS类

    using System; using System.Collections.Generic; using System.Text; using System.Web; using System.We ...

  6. September 2nd 2016 Week 36th Friday

    How does the world look through your eyes? 你眼里的世界是什么样子的? How does the world look through your eyes? ...

  7. javascript void运算符

    参考链接:http://www.cnblogs.com/ziyunfei/archive/2012/09/23/2698607.html语法: void expr 作用:计算表达式expr,并返回un ...

  8. jvm学习

    一.jps主要用来输出JVM中运行的进程状态信息 jps [options] [hostid] 如果不指定hostid就默认为当前主机或服务器. Jps -ml 二.jstack主要用来查看某个Jav ...

  9. httpclient 支持代理和http & https

    import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.Inpu ...

  10. 实现QQ在线咨询(需先添加好友)

    实现效果如图: 点击客服专员一.二.三之后提示添加qq好友,进行聊天. 代码如下: <div class="attachLeft"> <img src=" ...