Dom、事件

1.DOM对象中的innerHTMLinnerText有什么区别?

innerHTML获取元素节点和文本内容.innerText只获取文本内容.
举例:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
 <div id="content">
   <span class="description">你好</span>
 </div>
  <script>
    var a=document.getElementById("content").innerHTML;
    console.log(a);
    var b=document.getElementById("content").innerText;
    console.log(b);
  </script>
</body>
</html>

结果:


可以看到对象的innerHTML把它内部的所有元素都显示出来了,而innerText只显示文本.

2.elem.childrenelem.childNodes的区别?

elem.childrenelem.childNodes都是显示elem元素的子元素的数组.其中,elem.childNodeselem元素中如果有空白符,空白符也算作子元素,表示为text,而elem.childNodes则只包括标签之类的元素.举例:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
 <div id="content">
   <p class="para">哈哈</p>
   <span class="description">你好</span> <a class="link" href="#">hello</a>
 </div>
  <script>
        var a=document.getElementById("content").children;
        console.log(a);
    var b=document.getElementById("content").childNodes;
    console.log(b);
  </script>
</body>
</html>

结果:



如果把换行去掉:

<div id="content"><p class="para">哈哈</p><span class="description">你好</span> <a class="link" href="#">hello</a></div>

结果则为:



结果一样.

3.查询元素有几种常用的方法?

getElementById根据ID名查询.
示例:
代码:

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>查询元素</title>
    </head>
    <body>
        <div id="container">
            <ul>
                <li class="list">1</li>
                <li class="list">2</li>
                <li class="list">3</li>
            </ul>
            <form name="submit">
                <input type="text" name="description">
            </form>
        </div>
        <script>
            var containers=document.getElementById("container");
            console.log(containers);
            console.log(containers[0]);
            var cc=document.getElementById("cc");
            console.log(cc);
        </script>

结果:


getElementsByClassName根据class名查询.

var lists=document.getElementsByClassName("list");
  console.log(lists);
  console.log(lists[0]);


getElementsByTagName根据标签名查询.

var lists=document.getElementsByTagName("li");
  console.log(lists);
  console.log(lists[1]);


getElementsByName根据name名查询.

  var inputs=document.getElementsByName("description");
  console.log(inputs);
  console.log(inputs[0]);

jquery.Selector方法返回匹配指定的CSS选择器的元素节点。如果有多个节点满足匹配条件,则返回第一个匹配的节点。如果没有发现匹配的节点,则返回null。
jquery.SelectorAll方法返回所有匹配的CSS选择器的元素节点.
用法类似上面的几种,把上面的四种用法结合起来用这两种方法举例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>查询元素</title>
</head>
<body>
<div id="container">
  <ul>
    <li class="list">1</li>
    <li class="list">2</li>
    <li class="list">3</li>
  </ul>
  <form name="submit">
    <input type="text" name="description">
  </form>
</div>
<script>
  var containers=document.querySelector("#container");
  console.log(containers);
  console.log(containers[0]);
  var cc=document.querySelector("#cc");
  console.log(cc);
  var lists=document.querySelector(".list");
  console.log(lists);
  console.log(lists[0]);
  var lis=document.querySelectorAll(".list");
  console.log(lis);
  console.log(lis[0]);
  var inputs=document.querySelector("description");
  console.log(inputs);
</script>
</body>
</html>

结果:


4.如何创建一个元素?如何给元素设置属性?

createElement创建一个元素,setAttribute给这个元素设置属性.
举例:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
 <div id="content">
 <p class="para">哈哈</p>
 <span class="description">你好</span> 
 <a class="link" href="#">hello</a>
 </div>
  <script>
    var newspan=document.createElement('span');
    newspan.setAttribute("class","question");
    console.log(newspan);
    var newcontent=document.createTextNode("nihao");
    newspan.appendChild(newcontent);
    document.getElementById("content").appendChild(newspan);
  </script>
</body>
</html>

结果:


5.元素的添加、删除?

可以用createElement添加元素,appendChild()在元素的末尾添加元素,insertBefore()在某个元素之前添加元素.
举例:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>添加元素</title>
</head>
<body>
  <div id="container">
    <ul class="content">
      <li class="list">1</li>
      <li class="list">2</li>
      <li class="list">3</li>
    </ul>
  </div>
<script>
  var containers=document.querySelector('#container');
  var contents=document.querySelector('.content');
  var lists=document.querySelectorAll('.list');
  var paragraph=document.createElement('p');
  var description=document.createTextNode('你好');
  paragraph.appendChild(description);
  containers.appendChild(paragraph);//在div最后加一个p标签
</script>
</body>
</html>

结果:


还可以用insertBeforecontainers.appendChild(paragraph);换成
containers.insertBefore(paragraph,contents);,在列表ul前加一个段落p.

替换元素replaceChild(),删除元素removeChid().
在上述的代码后再加上contents.removeChild(lists[1]);,变为:

把上述js代码换成

<script>
  var containers=document.querySelector('#container');
  var contents=document.querySelector('.content');
  var lists=document.querySelectorAll('.list');
  var paragraph=document.createElement('p');
  var description=document.createTextNode('');
  paragraph.appendChild(description);
  contents.replaceChild(paragraph,lists[1]);
</script>

结果:


也可以去掉第二个li,但还会留下空间.

6.DOM0事件和DOM2级在事件监听使用方式上有什么区别?

DOM0把一个方法赋值给一个元素的事件处理程序属性。如果对同一事件,后面的处理程序会覆盖前面的.
DOM2一个事件可以有多个处理程序.

7.attachEventaddEventListener的区别?

attachEvent是IE8及以下浏览器的用法,addEventListener是其它大多数浏览器的用法.
主要有四点不同:
1.参数个数不相同,这个最直观,addEventListener有三个参数,attachEvent只有两个,attachEvent添加的事件处理程序只能发生在冒泡阶段,addEventListener第三个参数可以决定添加的事件处理程序是在捕获阶段还是冒泡阶段处理(我们一般为了浏览器兼容性都设置为冒泡阶段).
2.第一个参数意义不同,addEventListener第一个参数是事件类型(比如click,load),而attachEvent第一个参数指明的是事件处理函数名称(onclick,onload)
3.事件处理程序的作用域不相同,addEventListener的作用域是元素本身,this是指的触发元素,而attachEvent事件处理程序会在全局变量内运行,this是window.
4.为一个事件添加多个事件处理程序时,执行顺序不同,addEventListener添加会按照添加顺序执行,而attachEvent添加多个事件处理程序时顺序无规律(添加的方法少的时候大多是按添加顺序的反顺序执行的,但是添加的多了就无规律了),所以添加多个的时候,不依赖执行顺序的还好,若是依赖于函数执行顺序,最好自己处理,不要指望浏览器.

8.简述IE事件冒泡和DOM2事件传播机制

IE事件冒泡从内部元素查找到外部元素.即事件开始时由最具体的元素接收,然后逐级向上传播到较为不具体的元素.
DOM2先从外部一步步查找到内部,捕获到事件,再从内部冒泡到外部.具体包括三个阶段,事件捕获阶段,处于目标阶段,事件冒泡阶段,首先发生的是事件捕获,为截取事件提供机会,然后是实际目标接收事件,最后是冒泡阶段

9.如何阻止事件冒泡?如何阻止默认事件?

在IE中可以用element.cancelBubble==true阻止事件冒泡,其它浏览器中可以用element.stopPropagation()阻止事件冒泡.
比如:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>组织冒泡</title>
</head>
<body>
<div id="main">
  <span class="header">haha</span>
  <div id="container">
    <ul class="content">
      <li class="list">1</li>
      <li class="list">2</li>
      <li class="list">3</li>
    </ul>
  </div>
</div>
  <script>
    var lists=document.querySelectorAll(".list");
    lists[0].addEventListener('click',function(){
      lists[0].style.border="1px solid red";
    })
    var contents=document.querySelector(".content");
    contents.addEventListener('click',function(){
      contents.style.border="1px solid";
    })
  </script>
</body>
</html>

点击1输出为:


ul的边框也出现了.
加上阻止冒泡:

lists[0].addEventListener('click',function(event){
      lists[0].style.border="1px solid red";
      event.stopPropagation();
    })

结果则为:


只有1加上了边框.
阻止事件的默认行为,即阻止<a>,<form>标签等点击后有默认行为的元素的默认行为.
在IE中可以用event.returnValue==true阻止默认事件,其它浏览器中可以用event.preventDefault()阻止默认事件.
举例:
<a>标签上加上阻止默认事件.

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>阻止默认事件</title>
</head>
<body>
  <a href="http://www.baidu.com">链接</a>
</body>
</html>

为:

<script>
  var link=document.querySelector("a");
  link.addEventListener('click',function(event){
    event.preventDefault();
  })
</script>

就可以阻止a链接跳转到百度页面.

本文版权归本人和饥人谷所有,转载请注明出处

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、问答 1. dom对象的innerText和innerHTML有什么区别? innerHTML: 也就是从对象...
    饥人谷_罗伟恩阅读 649评论 0 2
  • 一、dom对象的innerText和innerHTML有什么区别? innerHTML返回的是从对象起始位置到终止...
    __Qiao阅读 428评论 0 0
  • dom对象的innerText和innerHTML有什么区别? innerHTML指的是从对象的起始位置到终止位置...
    coolheadedY阅读 508评论 0 0
  • 问答 一、dom对象的innerText和innerHTML有什么区别? innerTextinnerText是一...
    婷楼沐熙阅读 429评论 0 0
  • 问答 1、dom对象的innerText和innerHTML有什么区别? innerText属性①innerTex...
    鸿鹄飞天阅读 654评论 0 1