前端开发之JavaScript HTML DOM理论篇二
主要内容:
一、DOM元素
主要操作有添加、删除和替换HTML元素
1、创建新的HTML元素
(1)方法一: appendChild() 追加
如需向 HTML DOM 添加新元素,您首先必须创建该元素,然后把它追加到已有的元素上。
实例和解析:
<div id="box1">
<p id="p1">This is first paragraph.</p>
<p id="p1">This is second paragraph.</p>
</div> <script>
// 创建一个新的<p>元素
var para = document.createElement("p"); // 如需向<p>元素添加文本,你要首先创建文本节点,以下这句即为创建文本节点
var node = document.createTextNode("This is new!"); // 接下来,你要将文本节点追加到<p>元素中
para.appendChild(node); // 最后,要向已有的元素中追加这个元素,先查找到这个元素
var element = document.getElementById("box1"); // 将新元素添加到已有的元素中
element.appendChild(para); </script>
(2)方法二:insertBefore(new,old) 插入
实例:
<div id="box1">
<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 another one!"); // 创建文本节点
para.appendChild(node); // 向<p>中追加文本节点 var element = document.getElementById("box");// 查找<p>节点的父节点
var child = document.getElementById("p1"); // 找到<p>节点的同胞节点
element.insertBefore(para,child);// 将新创建的<p>节点插入到id为p1的同胞节点之前
2、删除已有的HTML元素
如需删除HTML元素,你需要知道该元素的父元素。
实例:
<div id="box1">
<p id="p1">This is a paragraph.</p>
<p id="p2">This is another paragraph.</p>
</div> <script>
// 获取父元素
var parent = document.getElementById("box1");
// 获取要删除的元素
var child = document.getElementById("p1");
// 删除该元素
parent.removeChild(child);
</script>
简略方法:找到您需要删除的子元素,然后使用 parentNode 属性来查找其父元素
var child = document.getElementById("p1");
child.parentNode.removeChild(child); // child.parentNode表示child的父元素
3、替换HTML元素
如需替换 HTML DOM 中的元素,请使用 replaceChild(new,old) 方法:
<div id="box1">
<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 new !");
para.appendChild(node); var parent = document.getElementById("box1");
var child = document.getElementById("p2");
parent.replaceChild(para,child);
</script>
二、HTML DOM事件
HTML DOM 允许 JavaScript 对 HTML 事件作出反应。
1、对事件做出反应
当事件发生时,可以执行 JavaScript,比如当用户点击一个 HTML 元素时。
如需在用户点击某个元素时执行代码,请把 JavaScript 代码添加到 HTML 事件属性中:
onclick = javaScript
实例:
// 当用户点击时,会改变 <h2> 元素的内容
<!DOCTYPE HTML>
<html lang="en">
<head>
<meta charset="utf-8">
</head>
<body>
<h2 onclick = "this.innerHTML='hello!'">请点击这段文本!有惊喜...</h2>
</body>
</html>
另一种写法 --- 从事件处理程序中调用函数
<!DOCTYPE HTMLl>
<html lang="en">
<head>
<meta charset="utf-8">
<script>
function changeText(id){
id = innnerHTML = "hello world!";
}
</script>
</head>
<body>
<h2 onclick="changetext(this)">请点击这段文本!</h2>
</body>
</html>
2、HTML 事件属性
如需向 HTML 元素分配事件,您可以使用事件属性。
实例 --- 当点击按钮时,会执行名为 displayDate 的函数。
<!DOCTYPE html>
<html>
<body> <p>点击按钮来执行 <strong>displayDate()</strong> 函数。</p> <button onclick="displayDate()">试一试</button>
<p id="demo"></p> </body>
<script>
function displayDate()
{
document.getElementById("demo").innerHTML = Date();
}
</script>
</html>
3、使用 HTML DOM 来分配事件
HTML DOM 允许您使用 JavaScript 向 HTML 元素分配事件。
实例:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
</head>
<body> <p>点击按钮来执行 <b>displayDate()</b> 函数。</p>
<button id=“myBtn”>试一试</button> <p id="demo"></p> </body>
<script>
document.getElementById("myBtn").onclick=function(){
displayDate();
}
function displayDate(){
document.getElementbyId("demo").innerHTML = Date();
}
</script>
</html>
4、onload 和 onunload 事件
当用户进入或离开页面时,会触发 onload 和 onunload 事件。
onload 事件可用于检查访客的浏览器类型和版本,以便基于这些信息来加载不同版本的网页。
onload 和 onunload 事件可用于处理 cookies。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
</head>
<body onload="checkCookies()"> <p>弹出的提示框会告诉你浏览器是否已启用 cookie。</p>
</body>
<script>
function checkCookies(){
if(navigator.cookieEnabled == true)
{
alert("Cookies are enabled");
}
else
{
alert("Cookies are not enabled");
}
}
</script>
</html>
5、onchange 事件
onchange事件常用于输入字段的验证。
实例 --- 当用户改变输入字段的内容时,将调用 upperCase() 函数。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
</head>
<body> 请输入你的英文名:<input type="text" id="fname" onchange="myFunction()">
<p>当你离开输入框时,被触发的函数会把你输入的文本转换为大写字母。</p>
</body>
<script>
function myFunction(){
var a = document.getElementById("fname");
a.value = a.value.toUpperCase();
}
</script>
</html>
6、onmouseover 和 onmouseout 事件
onmouseover 和 onmouseout 事件可用于在鼠标指针移动到或离开元素时触发函数。
实例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
</head>
<body>
</body>
<div
onmouseover="mOver(this)"
onmouseout="mOut(this)"
style="background-color:greenyellow;width:200px;height:50px;padding-top:25px;text-align:center;">
Mouse Over Me
</div>
<script>
function mOver(obj){
obj.innerHTML = "Thank you!";
obj.style.backgroundColor = "red";
}
function mOut(obj){
obj.innerHTML = "move here!";
obj.style.backgroundColor = "greenyellow";
}
</script>
</html>
7、onmousedown、onmouseup 以及 onclick 事件
onmousedown、onmouseup 以及 onclick 事件是鼠标点击的全部过程。首先当某个鼠标按钮被点击时,触发 onmousedown 事件,
然后,当鼠标按钮被松开时,会触发 onmouseup 事件,最后,当鼠标点击完成时,触发 onclick 事件。
实例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
</head>
<body>
<div onmousedown="mDown(this)" onmouseup="mUp(this)" style="background-color:#D94A38;width:200px;height:50px;padding-top:25px;text-align:center;">
点击这里
</div>
</body>
<script>
function mDown(obj){
obj.style.backgroundColor = "green";
obj.innerHTML = "松开鼠标";
}
function mUp(obj){
obj.style.backgroundColor = "yellow";
obj.innerHTML = "谢谢!";
}
</script>
</html>
前端开发之JavaScript HTML DOM理论篇二的更多相关文章
- 前端开发之JavaScript HTML DOM理论篇一
主要内容: 1.DOM简介 2.DOM 节点 3.DOM 方法和属性 4.DOM 访问和修改 一.DOM简介 1.什么是 DOM? DOM 是 W3C(万维网联盟)的标准. DOM 定义了访问 HTM ...
- 前端开发之JavaScript HTML DOM实战篇
实战案例一: “灯泡发光” <!DOCTYPE html> <html lang="en"> <head> <meta charset=& ...
- 前端开发之JavaScript篇
一.JavaScript介绍 前端三剑客之JavaScript,简称js,可能是这三个里面最难的一个了.很早以前,市面上流通着三种js版本,为了统一,ECMA(欧洲计算机制造协会)定义了规范的版本, ...
- 前端开发之JavaScript基础篇一
主要内容: 1.JavaScript介绍 2.JavaScript的引入方法和输出及注释 3.javaScript变量和命名规则 4.五种基本数据类型 5.运算符 6.字符串处理 7.数据类型转换 ...
- 前端开发之javascript BOM篇
主要内容: 1.BOM输出 2.BOM的对象 3.client的相关属性 4.offset的相关属性 5.scroll的相关属性 前情提要: 何谓BOM? 所谓 BOM 指的就是浏览器对象模型 Bro ...
- 前端开发之JavaScript基础篇三
主要内容: 1.创建对象的几种方式 2.JavaScript内置对象 3.JavaScript错误--Throw.Try 和 Catch 4.JavaScript 表单验证 一.创建对象的几种方式 1 ...
- 前端开发之JavaScript基础篇四
主要内容: 1.定时器 2.正则表达式入门 3.元字符 4.正则表达式实战运用 一.定时器 javaScript里主要使用两种定时器,分别是:setInterval()和setTimeout(). 1 ...
- 前端开发之JavaScript基础篇二
主要内容: 1.流程控制条件语句和switch语句 2.for循环和while循环 3.Break语句和Continue语句 4.数组和数组常用方法 5.函数 6.对象 一.流程控制条件语句和swit ...
- 前端开发之BOM和DOM(转载)
BOM BOM:是指浏览器对象模型,它使JavaScript可以和浏览器进行交互. 1,navigator对象:浏览器对象,通过这个对象可以判定用户所使用的浏览器,包含了浏览器相关信息. naviga ...
随机推荐
- C++ sort 函数用法
MSDN中的定义: template<class RanIt>void sort(RanIt first, RanIt last); //--> 1)template<clas ...
- 20165212 学习基础和C语言基础调查
学习基础与C语言基础调查 阅读文章的心得体会 五篇文章都从不同角度阐述了毅力的重要性,打字.减肥.运动各方面,比如“每天一万步”这个任务,人们通过建群聊互相监督.“打卡”的方式来实现坚持的目的,我认为 ...
- fpga配置过程(转载)
fpga 配置时序图如下 1.FPGA器件有三类配置下载方式:主动配置方式(AS)和被动配置方式(PS)和最常用的(JTAG)配置方式. AS 由FPGA器件引导配置操作过程, ...
- 用oradebug short_stack及strace -p分析oracle进程是否dead或出现故障
1,可以采用oradebug或者strace -p跟踪后台或前台进程是否dead或hang住2,如果进程出现故障,必会在对应的TRC文件写入最新信息,基于此可以获取非常重要的信息进一步分析与诊断 ...
- bzoj 2597 [Wc2007]剪刀石头布——费用流
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2597 三个人之间的关系,除了“剪刀石头布”,就是有一个人赢了2局:所以考虑算补集,则每个人对 ...
- LNMP.ORG 安装LNMP
参考:http://lnmp.org/install.html cd /usr/local/src wget -c http://soft.vpser.net/lnmp/lnmp1.3-full.ta ...
- 在 myeclipse中进行连接sql server的测试
在 myeclipse中,连接 sql server 用的 url connection 与 java 代码 连接的 url值完全相同. (一下为 java的jdbc连接 sql server 成功的 ...
- Linux之安装软件
1. 下载获得redis-3.0.4.tar.gz后将它放入我们的Linux目录/opt 2. 在SecureCRT界面上点SecureFX图标 在本地窗口中找到要上传的文件 在要上传的文件上点右键 ...
- Java中split的用法
Java中的我们可以利用split把字符串按照指定的分割符进行分割,然后返回字符串数组,下面是string.split的用法实例及注意事项:java.lang.string.splitsplit 方法 ...
- mysql索引之一:索引基础(B-Tree索引、哈希索引、聚簇索引、全文(Full-text)索引区别)(唯一索引、最左前缀索引、前缀索引、多列索引)
没有索引时mysql是如何查询到数据的 索引对查询的速度有着至关重要的影响,理解索引也是进行数据库性能调优的起点.考虑如下情况,假设数据库中一个表有10^6条记录,DBMS的页面大小为4K,并存储10 ...