现在来说说DOM
文档对象模型DOM(Document Object Model)定义访问和处理html文档的标准方法。DOM将html文档呈现为带有元素
 
,属性和文本的树结构(节点树)
先来看看下列代码
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=gb2312">
<title>DOM</title>
</head>
<body>
   <h2><a href="http://www.baidu.com">javascript DOM</a></h2>
   <p>对HTML元素进行操作,可添加,改变或移除CSS样式等</p>
   <ul>
       <li>JavaScript</li>
       <li>DOM</li>
       <li>CSS</li>
   </ul>
</body>
</html>
html文档可以说由节点构成的集合,三种常见的DOM节点:
1.元素节点:如<html>、<body>、<p>等都是元素节点,即标签。
2.文本节点:向用户展示的内容,如<li>...</li>种的JavaScript、DOM、CSS等文本
3.属性节点:元素属性,如<a>标签的链接属性href="http://www.baidu.com"
看下面的代码:
<a href="http://www.baidu.com">JavaScript DOM</a>
这里面href="http://www.baidu.com"是属性节点 JavaScript DOM是文本节点
首先,通过ID获取元素
学过HTML/CSS样式,都知道,网页由标签将信息组织起来,而标签的id属性值是唯一的,就像是每人有一个身份证号
 
一样,只要通过身份证号就可以找到相对应的人,那么在网页中我们通过id先找到标签,然后进行操作。
语法:
document.getElementById("id")
今天晚上暂时更新到这里。。明天我继续更新。。。。。。

接上面的。下面继续:

下面来看看代码:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type
content="text/html;charset=gb2312">
<title>获取元素</title>
  <script type="text/javascript">
   var mye=document.getElementById("con");//获取元素存储在变量mye中
   document.write(mye);//输出变量mye
  </script>
</head>
 
<body>
   <h3>Hello</h3>
   <p id="con">I Love JavaScript</p>
</body>
</html>
结果:null或者[object HTMLParagraphElement]
注意:获取的元素是一个对象,如想对元素进行操作,我们要通过它的属性或方法。
innerHTML属性用于获取或替换HTML元素的内容
语法:
Object.innerHTML
注意:
1.Object是获取的元素对象,如通过document.getElementById("ID")获取的元素
2.注意书写,innerHTML区分大小写
我们通过id="con"获取<p>元素,并将元素的内容输出和改变元素内容,如下:
<!DOCTYPE HTML>
<html>
<head>
<title>innerHTML</title>
</head>
<body>
  <p id="con">Hello World!</p>
  <script>
    var mycon=document.getElementById("con");
    document.write("p标签原始内容:"+mycon.innerHTML+"<br>");
    //输入元素内容
    mycon.innerHTML="New text!"//修改p元素内容
    document.write("p标签修改后的内容为:"+mycon.innerHTML);
  </script>
</body>
</html>
注意!!!看清楚,这里的innerTHML是可以获取!还有!替换!的!既可以获取,
又可以替换!懂了没有!不要再询问为什么前面也可以得到原始内容!看清楚!
然后HTML DOM允许JavaScript改变HTML元素的样式,如何改变HTML元素的样式呢?
语法:
Object.style.property=new style;
注意:Object是获取的元素对象,如通过document.getElementById("id")获取的
元素。
属性表如下:
属性     描述
backgroundColor 设置元素背景色
height 设置元素高度
width 设置元素宽度
color 设置文本的颜色
font 在一行设置所有的字体属性
fontFamily 设置元素的字体系列
fontSize 设置元素的字体大小
注意:这个表只是一小部分的css样式属性,其他的样式也可以通过该方法设置和
修改。
看看下面代码:
改变<p>元素的样式,将颜色改为红色,字号改为20,背景色改为蓝色:
<p id="pcon">Hello World!</p>
<script>
  var kk=document.getElementById("pcon");
  kk.style.color="red";
  kk.style.fontSize="20";
  kk.style.backgroundColor="blue";
</script>
网页中擦很难过常会看到显示和隐藏的效果,可以通过display属性来设置
语法:
Object.style.display=value
注意:Object是获取的元素对象,如通过document.getElementById("id")获取的
元素。
value取值:
值      描述
none 此元素不会被显示(即隐藏)
block 此元素将显示为块级元素(即显示)
看下面代码:
<!DOCTYPE THML>
<html>
<head>
<meta http-equiv="Content-Type"
content="text/html,charset=gb2312">
<title>display</title>
  <script type="text/javascript">
    function hidetext()
    {
      document.getElementById("con").style.display="none";
    }
    function showtext()
    {
      document.getElementById("con").style.display="block";
    }
   </script>
</head>
<body>
  <h1>JavaScript</h1>
  <p id="con">
作为一个web开发者来说,如果你想提供漂亮的网页,令客户满意的上网体验,JavaScript
是必不可少的工具。</p>
 <form>
   <input type="button" onclick="hidetext()" value="不显示段落内容">
   <input type="button" onclick="showtext()" value="显示段落内容">
</body>
</html>
接下来说一说控制类名(className属性)
className属性设置或返回元素的class属性。
语法:
Object.className=classname
作用:
1.获取元素的class属性
2.为网页内的某个元素指定一个css样式来更改该元素的外观
看看下面的代码,获得<p>元素的class属性和改变className:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type"
content="text/htlm,charset=gb2312">
<title>className属性</title>
<style type="text/css">
  input{font-size:10px;}
  .one{
        width:200px;
        background-color:#ccc;
      }
   .two{
      font-size:18px;
      color:#FOO;
}
</style>
</head>
<body>
 <p id="con" class="one">JavaScript</p>
 <form>
   <input type="button" value="点击修改" onclick="modifyclass()"/>
 </form>
 <script type="text/javascript">
   var mychar=document.getElementById("con");
   document.write("p元素Class值为:"+mychar.className+"</br>");
   //输出p元素Class属性
   function modifyclass(){
    mychar.className="two";//改变className
}
 </script>
</body>
</html>
这里注意!这个地方的className还有前面提到的getElementById等等都必须严格
遵循驼峰法,否则将不起作用。

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 ...

随机推荐

  1. [整理]Breakpoint on arbitrary selector

    基本解释了最近在调试时遇到的一些疑问,接下来就是找解决方法了. //-- Begin: 1 T __mh_execute_header 0000000005614542-000000 OPT radr ...

  2. Leetcode: 06/01

    今天完成了三道题目,总结一下: 1: Length of last word(细节实现题) 此题有一些细节需要注意(比如 “a_ _” 最后一个单词是a, 而不是遇到空格就直接算成没有),别的基本就是 ...

  3. 《C++游戏开发》笔记十三 平滑过渡的战争迷雾(一) 原理:Warcraft3地形拼接算法

    本系列文章由七十一雾央编写,转载请注明出处.  http://blog.csdn.net/u011371356/article/details/9611887 作者:七十一雾央 新浪微博:http:/ ...

  4. ORA-12520错误解决方法

    ORA-12520监听程序无法为请求的服务器类型找到可用的处理程序 以下不知道是不是解决方法的方法,因为我只重启下oracle服务就好了,并没进行任何修改 引用别人的文章: 1)数据库是专用服务器,但 ...

  5. jquery animate stop函数解析

    今天我们来看看jquery中动画操作的stop函数.其实我至今不是很明白啊,所以此文算是求救以及抛砖引玉. 在jquery 1.7版本以前,stop支持两个参数,分别是clearQueue和jumpT ...

  6. Mongodb 集群搭建以及常见错误

    Mongodb 集群搭建以及常见错误 1 关于Replica Sets +Sharding(主从复制加分片)搭建,不这详细去说,网上有很多,大部分的例子就三台服务器之间做主从复制,分2个shard,架 ...

  7. EM算法详解

    EM算法详解 1 极大似然估计 假设有如图1的X所示的抽取的n个学生某门课程的成绩,又知学生的成绩符合高斯分布f(x|μ,σ2),求学生的成绩最符合哪种高斯分布,即μ和σ2最优值是什么? 图1 学生成 ...

  8. CSS 实现的各种球体效果

    CSS 实现的各种球体效果[附在线演示] CSS 可以实现很多你想不到的效果,今天我们来尝试使用 CSS 实现各种球体效果.有两种方法可以实现,第一种是使用大量的元素创建实际的 3D 球体,这种方法有 ...

  9. python supervisor demo deployment

    I did a demo about how to deploy other python apps served by a 'supervisord' daemon processor on git ...

  10. Python之路3Day

    3.python基础补充(集合,collection系列,深浅拷贝)   一.集合 1.集合(set): 把不同的元素组成一起形成集合,是python基本的数据类型.集合元素(set elements ...