1.DOM对象中的innerHTML
和innerText
有什么区别?
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.children
和elem.childNodes
的区别?
elem.children
和elem.childNodes
都是显示elem
元素的子元素的数组.其中,elem.childNodes
在elem
元素中如果有空白符,空白符也算作子元素,表示为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>
结果:
还可以用
insertBefore
把containers.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.attachEvent
和addEventListener
的区别?
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
链接跳转到百度页面.
本文版权归本人和饥人谷所有,转载请注明出处