第十四课
DOM技术概述
1:DOM概述

  文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。DOM 将HTML文档呈现为带有元素、属性和文本的树结构(节点树)。
    DOM是一种与浏览器,平台及语言无关的接口,能够以编程方式
    访问和操作文档
    1、DOM是Document Object Model(文档对象模型)的简称
    2、提供了访问,操作该模型的API
    
2:DOM的分层结构
    在DOM中,文档的层次结构被表示为树形结构。树是倒立的,树根在上
    树叶在下面,树的节点表示文档的内容
    
    子节点:   在树形结构中,直接位于一个节点之下的节点被称为该节点的子节点
    父节点:   直接位于一个节点之上的节点被称为该节点的父节点
    兄弟节点: 具有相同父节点的节点是兄弟节点
    后代:     一个节点的下一个层次的节点集合石该节点的后代
    祖先:     一个节点的父节点,祖先节点以及其他所有位于它之上的节点都是该节点的祖先

3:HTML文档可以说由节点构成的集合,三种常见的DOM节点:

   3.1. 元素节点:上图中<html>、<body>、<p>等都是元素节点,即标签。

 

   3.2. 文本节点:向用户展示的内容,如<li>...</li>中的JavaScript、DOM、CSS等文本。

 

   3.3. 属性节点:元素属性,如<a>标签的链接属性href="http://www.imooc.com"。

案例代码如下

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title> </head>
<body>
<p id="p1">我的第一段文字</p> <p id="p2">我的第二段文字</p>
<script language="javascript">
document.write("hello");
document.getElementById("p1").style.color="blue";
document.getElementById("p2").style.color="red";
</script>
</body>
</html>

案例运行结果如下


1:通过ID获取元素 document.getElementById();的用法

学过HTML/CSS样式,都知道,网页由标签将信息组织起来,而标签的id属性值是唯一的,就像是每人有一个身份证号一样,只要通过身份证号就可以找到相对应的人。那么在网页中,我们通过id先找到标签,然后进行操作。

案例1源码如下     

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title> </head>
<body> <p id="p1">锄禾日当午,汗滴禾下土</p>
<script language="javascript">
var v=document.getElementById("p1");
document.write(v);
</script>
</body>
</html>

案例1运行结果如下



   

2:innerHTML 属性 

语法 Object.innerHTML

innerHTML 属性用于获取或替换 HTML 元素的内容。

注意:

1.Object是获取的元素对象,如通过document.getElementById("ID")获取的元素。

2.注意书写,innerHTML区分大小写。

案例如下(获取元素)

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title> </head>
<body> <p id="p1">锄禾日当午,汗滴禾下土</p>
<script language="javascript">
var v=document.getElementById("p1").innerHTML;
document.write(v);
</script>
</body>
</html>

案例代码运行如下

案例2源码如下(替换元素)

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title> </head>
<body> <p id="p1">锄禾日当午,汗滴禾下土</p>
<script language="javascript">
var v=document.getElementById("p1");
document.write("原始的元素:"+v.innerHTML+"<br/>");
v.innerHTML="窗前明月光,疑似地上霜";
document.write("替换后的元素:"+v.innerHTML+"<br/>");
</script>
</body>
</html>

案例2运行如下

3:改变 HTML 样式

HTML DOM 允许 JavaScript 改变 HTML 元素的样式。如何改变 HTML 元素的样式呢?

语法:

Object.style.property=new style;

注意:Object是获取的元素对象,如通过document.getElementById("id")获取的元素。

基本属性表(property):

案例代码如下

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title> </head>
<body> <p id="p1">锄禾日当午,汗滴禾下土</p>
<script language="javascript">
var v=document.getElementById("p1");
v.style.color="blue";
v.style.fontFamily="楷体";
v.style.fontSize=50;
v.style.backgroundColor="red";
</script>
</body>
</html>

案例运行如下

4:显示和隐藏(display属性)

网页中经常会看到显示和隐藏的效果,可通过display属性来设置。

语法:

Object.style.display = value

注意:Object是获取的元素对象,如通过document.getElementById("id")获取的元素。

value的取值

案例代码如下

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title>
<script language="javascript">
function dis1(){
document.getElementById("p1").style.display="block";
}
function dis2(){
document.getElementById("p1").style.display="none";
} </script>
</head>
<body>
<p>显示和隐藏功能</p>
<p id="p1">锄禾日当午,汗滴禾下土,谁知盘中餐,粒粒皆辛苦</p>
<from>
<input type="button" value="显示内容" onclick="dis1()">
<input type="button" value="隐藏内容" onclick="dis2()">
</from>
</body>
</html>

案例运行结果如下

        

5:控制类名(className 属性)

className 属性设置或返回元素的class 属性。

语法:

object.className = classname

作用:

1.获取元素的class 属性

2. 为网页内的某个元素指定一个css样式来更改该元素的外观

案例代码如下

 <html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>初识DOM</title>
<style type="text/css">
.one{
border:1px solid red;
width:300px;
height:100px;
background:blue;
color:green;
}
.two{
border:2px solid blink;
width:300px;
height:100px;
background:green;
color:blue;
}
</style>
</head>
<p id="p1" class="one">JavaScript使网页显示动态效果并实现与用户交互功能。</p> <form>
<input type="button" value="更改样式" onclick="modify()"/>
</form> <p id="p2">JavaScript使网页显示动态效果并实现与用户交互功能。</p> <form>
<input type="button" value="添加样式" onclick="add()"/>
</form>
<script language="javascript">
function modify(){
var v1=document.getElementById("p1");
v1.className="two";
}
function add(){
var v2=document.getElementById("p2");
v2.className="two";
}
</script>
</html>

案例运行结果如下

            

 



综合练习源码如下

 <!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" Content="text/html; charset=utf-8" />
<title>javascript</title> <style type="text/css">
body{font-size:12px;}
#txt{
height:400px;
width:600px;
border:#333 solid 1px;
padding:5px;}
p{
line-height:18px;
text-indent:2em;}
</style>
</head>
<body>
<h2 id="con">JavaScript课程</H2> <div id="txt">
<h5>JavaScript为网页添加动态效果并实现与用户交互的功能。</h5>
<p>1. JavaScript入门篇,让不懂JS的你,快速了解JS。</p>
<p>2. JavaScript进阶篇,让你掌握JS的基础语法、函数、数组、事件、内置对象、BOM浏览器、DOM操作。</p>
<p>3. 学完以上两门基础课后,在深入学习JavaScript的变量作用域、事件、对象、运动、cookie、正则表达式、ajax等课程。</p>
</div> <form>
<!--当点击相应按钮,执行相应操作,为按钮添加相应事件-->
<input type="button" value="改变颜色" onclick="changeColor()">
<input type="button" value="改变宽高" onclick="changeHeight()">
<input type="button" value="隐藏内容" onclick="changeNone()">
<input type="button" value="显示内容" onclick="changeDisplay()">
<input type="button" value="取消设置" onclick="changeStart()">
</form> <script type="text/javascript">
//定义"改变颜色"的函数
function changeColor()
{
var mychar=document.getElementById("txt");
mychar.style.color="red";
} //定义"改变宽高"的函数
function changeHeight()
{
var mychar=document.getElementById("txt");
mychar.style.height="150px";
} //定义"隐藏内容"的函数
function changeNone()
{
var mychar=document.getElementById("txt");
mychar.style.display="none";
} //定义"显示内容"的函数
function changeDisplay()
{
var mychar=document.getElementById("txt");
mychar.style.display="block";
} //定义"取消设置"的函数
function changeStart()
{
var start=confirm("你是否取消设置?");
if(start==true){
var start=document.getElementById("txt");
start.style.color="";
start.style.width="600px";
start.style.height="400px";
start.style.background="";
}else{
alert("你没有取消设置");
}
} </script>
</body>
</html>

综合练习运行结果如下

Javascript中DOM技术的的简单学习的更多相关文章

  1. Javascript中String对象的的简单学习

    第十一课String对象介绍1:属性    在javascript中可以用单引号,或者双引号括起来的一个字符当作    一个字符对象的实例,所以可以在某个字符串后再加上.去调用String    对象 ...

  2. 在JavaScript中闭包的作用和简单的用法

    在JavaScript中闭包的作用和简单的用法 一.闭包的简介 作用域链:在js中只有函数有作用域的概念,由于函数内能访问函数外部的数据,而函数外部不能访问函数内部的数据,由上述形成一种作用域访问的链 ...

  3. day29—JavaScript中DOM的基础知识应用

    转行学开发,代码100天——2018-04-14 JavaScript中DOM操作基础知识即对DOM元素进行增删改操作.主要表现与HTML元素的操作,以及对CSS样式的操作.其主要应用知识如下图: 通 ...

  4. js学习笔记----JavaScript中DOM扩展的那些事

    什么都不说,先上总结的图~   Selectors API(选择符API) querySelector()方法 接收一个css选择符,返回与该模式匹配的第一个元素,如果没有找到匹配的元素,返回null ...

  5. Android与javascript中事件分发机制的简单比较

    在前面两篇博客中,我们讨论了Android中的事件分发的相关内容,那么在本篇博客当中,我们就简单探讨一下html或javascript中的事件分发机制,并进行简单的对比. 在前端中,对事件进行绑定有三 ...

  6. JavaScript中DOM的层次节点(一)

    DOM是针对HTML和XML文档的一个API,描绘了一个层次化的节点树,允许开发人员添加.修改.删除节点的一部分. DOM将HTML和XML文档描绘成一个有多个节点构成的结构,节点分为12种不同的节点 ...

  7. Javascript中几个看起来简单,却不一定会做的题

    Javascript作为前端开发必须掌握的一门语言,因为语言的灵活性,有些知识点看起来简单,在真正遇到的时候,却不一定会直接做出来,今天我们就一起来看看几道题目吧 题目1 var val = 'smt ...

  8. 关于Javascript中页面动态钟表的简单实现

    1.问题并不繁琐,在于HTML中 DOM(文档对象模型)方法的掌握,我的钟表实现重点用到了三个函数和一个事件 A)setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式.s ...

  9. JAVAScript中DOM与BOM的差异分析

    JAVAScript 有三部分构成,ECMAScript,DOM和BOM,根据浏览器的不同,具体的表现形式也不尽相同.我们今天来谈一谈DOM和BOM这俩者之间的差异. 用百科上的来说: 1. DOM是 ...

随机推荐

  1. 开发Android应用怎么更改LOGO图标

    开发安卓应用怎么更改LOGO图标,我们知道我们开发安卓程序的时候,都需要给他整一个logo,一般开发程序都会自动一个图标,我们怎么给他更换自己想要的logo图标,之前大家看过我们写的怎么安装程序到虚拟 ...

  2. Selenium2+python自动化20-Excel数据参数化

    前言 问: Python 获取到Excel一列值后怎么用selenium录制的脚本中参数化,比如对登录用户名和密码如何做参数化? 答:可以使用xlrd读取Excel的内容进行参数化.当然为了便于各位小 ...

  3. Selenium简单介绍

    WEB自动化测试:指WEB应用系统从用户界面层面进行的自动化测试.通过用户界面测试内部的业务逻辑. 自身特点:(一)WEB页面上出现的元素有可能具有不确定性: (二)不同操作系统上不同WEB浏览器之间 ...

  4. 设置h5页面不可复制文字

    * { moz-user-select: -moz-none; -moz-user-select: none; -o-user-select: none; -khtml-user-select: no ...

  5. HDU 2689Sort it 树状数组 逆序对

    Sort it Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Sub ...

  6. lvm snapshot(lvm 快照)

    lvm快照有多种实现方法,其中一种是COW(Copy-On-Write),不用停止服务或将逻辑卷设为只读就可以进行备份,当一个 snapshot创建的时候只是拷贝原始卷里的元数据,而不是物理上的数据, ...

  7. Top Data Scientists to Follow & Best Data Science Tutorials on GitHub

    http://www.analyticsvidhya.com/blog/2015/07/github-special-data-scientists-to-follow-best-tutorials/ ...

  8. 正向代理与反向代理的区别【Nginx读书笔记】(zz)

    正向代理与反向代理的区别[Nginx读书笔记]       正向代理的概念 正向代理,也就是传说中的代理,他的工作原理就像一个跳板,简单的说,我是一个用户,我访问不了某网站,但是我能访问一个代理服务器 ...

  9. who is the middle

    Description FJ is surveying his herd to find the most average cow. He wants to know how much milk th ...

  10. Android Studio签名打包的两种方式

    签名打包的两种方式: 注:给我们自己开发的app签名,就代表着我自己的版权,以后要进行升级,也必须要使用相同的签名才行.签名就代表着自己的身份(即keystore),多个app可以使用同一个签名. 如 ...