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链接跳转到百度页面.

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,718评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,683评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,207评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,755评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,862评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,050评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,136评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,882评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,330评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,651评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,789评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,477评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,135评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,864评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,099评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,598评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,697评论 2 351

推荐阅读更多精彩内容

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