JavaScript从入门到放弃之重中之重DOM篇(一)

DOM

  DOM,英文全称是Docuemnt Object Model ,翻译过来就是文档对象模型。那么顾名思义我们的DOM操作就是操作我们的文档对象,大白话来说就是找到我们需要的那一个或多个标签,修改他们的各种属性。

  用官方一点的话来说就是,所谓DOM,全称 Docuemnt Object Model 文档对象模型,毫无疑问,此时要操作对象,什么对象?文档对象在文档中一切皆对象,比如html,body,div,p等等都看做对象,那么我们如何来点击某个盒子让它变色呢?DOM 为文档提供了结构化表示,并定义了如何通过脚本来访问文档结构。目的其实就是为了能让js操作html元素而制定的一个规范。


Dom树

接下来我们来了解一个叫做DOM树的东西,既然叫树,当然树有根,叶子,节点,显然这就是一种带父子关系的树,下面用一张图来表示如下状态:

打个比方,我们的一个html文件相当于一棵树的所有东西,各种标签组成了这棵树,如上图从上向下慢慢分化出分支,组成了一棵树。

在HTML当中,一切都是节点:(非常重要)

  • 元素节点:HMTL标签。
  • 文本节点:标签中的文字(比如标签之间的空格、换行)
  • 属性节点::标签的属性

整个html文档就是一个文档节点。所有的节点都是Object。


 

DOM可以做什么


 一些基本的DOM获取方式

    //获得文档对象
    console.log(document);
    //2.获取html
    console.log(document.documentElement);
    console.dir(document.documentElement);
    //3.获取body
    console.log(document.body);
    //获取body中元素节点对象的三种方式
    //4.1通过id获取
    var a = document.getElementById('i1');
    console.log(a);
    //4.2通过类名获取
    var b = document.getElementsByClassName('box')[0];//数组形式,所以有S
    console.log(b)
    //通过标签名获取
    var c = document.getElementsByTagName('div')[1];
    console.log(c)

JS是事件驱动为核心的一门语言

事件的三要素:事件源、事件、事件驱动程序。

比如,我用手去按开关,灯亮了。这件事情里,事件源是:手。事件是:按开关。事件驱动程序是:灯的开和关。

再比如,网页上弹出一个广告,我点击右上角的X,广告就关闭了。这件事情里,事件源是:X。事件是:onclick。事件驱动程序是:广告关闭了。

于是我们可以总结出:谁引发的后续事件,谁就是事件源。

总结如下:

  • 事件源:引发后续事件的html标签。
  • 事件:js已经定义好了(见下图)。
  • 事件驱动程序:对样式和html的操作。也就是DOM。

    代码书写步骤如下:(重要)

  • (1)获取事件源:document.getElementById(“box”); //类似与ios语言的UIButton *adBtn = [UIButton buttonWithType:UIButtonTypeCustom];

  • (2)绑定事件: 事件源box.事件onclick = function(){ 事件驱动程序 };

  • (3)书写事件驱动程序:关于DOM的操作

常用事件:


DOM绑定事件

    //绑定事件的方法
    var a =document.getElementById('i1'); //获取事件源
    a.onclick=function () {//事件
        alert(1)//事件驱动
    }

  先单独定义函数,再绑定

 var oDiv = document.getElementById("box");
    //绑定事件的第二种方式
    oDiv.onclick = fn;   //注意,这里是fn,不是fn()。fn()指的是返回值。
    //单独定义函数
    function fn() {
        alert("我是弹出的内容");
    };

  行内绑定

<!--行内绑定-->
<div id="box" onclick="fn()"></div>

<script type="text/javascript">

    function fn() {
        alert("我是弹出的内容");
    }

</script>

  注意第一行代码,绑定时,是写的"fn()",不是写的"fn"。因为绑定的这段代码不是写在js代码里的,而是被识别成了字符串。


JavaScript入口函数 window.onload()

此函数调用,是当页面加载完毕(文档和图片)的时候,触发onload()函数,文档先加载,图片资源后加载

 

<script type="text/javascript">
    window.onload = function () {
        console.log("alex");  //等页面加载完毕时,打印字符串
    }
</script>

  

有一点我们要知道:js的加载是和html同步加载的。因此,如果使用元素在定义元素之前,容易报错。这个时候,onload事件就能派上用场了,我们可以把使用元素的代码放在onload里,就能保证这段代码是最后执行。

window.onload()方法存在的问题

  • 图片加载完成才调用onload方法,大家想个问题,如果现在用户访问JD商城页面,如果JD商城中的脚本文件在window.onload()方法调用,如果此时用户网速卡了,然后图片资源加载失败了,此时用户是做不了任何操作的,所以winodw.onload()方法有很大问题。
  • window.onload()方法 如果脚本中书写两个这样的方法,那么会有事件覆盖现象。

 

DOM属性操作

 

 实现盒子的颜色切换,话不多说,上代码:

    var isRed = true;
    a.onclick=function () {//事件  是一种异步操作
        //alert(1)//事件驱动
        if (isRed) {
            a.style.backgroundColor = 'green'
            isRed = false
        }
        else {
            a.style.backgroundColor = 'red'
            isRed = true
        }
    }

值的操作

所谓值的操作,就是对前闭合标签和后闭合标签中间的文本内容的设置和获取。

  • 双闭合标签: innerText或者innerHTML
  • 单闭合标签:除了img标签,就剩input了,使用value进行赋值

  

<div id='box'></div>
<input type='text' value = 'alex' id='user'>
<script>
    window.onload = function(){
        //1.获取事件源(事件对象,在文档中一切的标签都是对象)
        var oDiv = docuement.getElementById('box');
         var oInput = docuement.getElementById('user');
        //2.事件
        oDiv.onclick = function(){
            //3.事件驱动程序  
            oDiv.innerText = 'alex';//仅仅设置文本内容
            oDiv.innerHTML = '<h1>alex</h1>';//将标签和文本内容一起解析
        };

        //2.事件
        oInput.onclick = function(){
            //3.事件驱动程序   只有有value属性的 才能使用value赋值和设置值
            oInput.value = 'wusir';
        }
    };

</script>

标签的属性操作 

<script>
    window.onload=function () {
        var a =document.getElementById('i1')
        a.onmouseover = function () {
            a.src = '2.JPG'
        }
        a.onmouseleave = function () {
            a.src = '1.JPG'
        }
    }
</script>

 

有关属性的获得操作:(和字典的操作类似)

显示隐藏的两种方式

方式一:

 

通过添加类来实现隐藏:

图中添加一个空格的小技巧实现类的添加

 

DOM节点的操作

都是函数(方法)

创建节点

格式如下:

新的标签(元素节点) = document.createElement("标签名");

比如,如果我们想创建一个li标签,或者是创建一个不存在的adbc标签,可以这样做:

<script type="text/javascript">
    var a1 = document.createElement("li");   //创建一个li标签
    var a2 = document.createElement("adbc");   //创建一个不存在的标签

    console.log(a1);
    console.log(a2);

    console.log(typeof a1);
    console.log(typeof a2);
</script>

  

插入节点

插入节点有两种方式,它们的含义是不同的。

方式1:

 父节点.appendChild(新的子节点);

解释:父节点的最后插入一个新的子节点。

方式2:

父节点.insertBefore(新的子节点,作为参考的子节点);

  

解释:

  • 在参考节点前插入一个新的节点。
  • 如果参考节点为null,那么他将在父节点最后插入一个子节点。

删除节点

格式如下:

  父节点.removeChild(子节点);

  

解释:用父节点删除子节点。必须要指定是删除哪个子节点。

如果我想删除自己这个节点,可以这么做:

node1.parentNode.removeChild(node1);

 相关操作:

<div id="i1" class="box1">我是你爹</div>
<script>
    var a = document.createElement('div');
    var b = document.getElementById('i1');
    a.setAttribute('class','a');
    b.appendChild(a);
    console.log(a)
</script>

 有关JS里面的this理解

类似于python里面的self,谁调用的事件,this指的就是谁(请勿搞错调用的那个对象)

posted @ 2018-11-28 21:41  Recklessz  阅读(210)  评论(0编辑  收藏  举报