美文网首页
vip10-dom事件170120

vip10-dom事件170120

作者: 饥人谷_小霾 | 来源:发表于2017-01-20 15:32 被阅读0次

题目1:dom对象的innerTextinnerHTML有什么区别?


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

题目2:elem.childrenelem.childNodes的区别?


  • elem.children:这是一个只读属性,返回一个包含当前元素的子元素集合,HTMLCollection(live)

  • elem.childNodes:获取所有子节点,返回一个NodeList集合,除了HTML元素节点,该属性返回的还包括Text节点和Comment节点。

  • 准确的说elem.childrenelem.childNodes是不同的2个概念,其中elem.childNodes应该是node.childNodes

  • Node包括element节点,而children是element属性,childNode是node的属性,所以children和node没有直接的联系,Node的children属性为undefined,html中空白的部分在node.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>

结果:

题目3:查询元素有几种常见的方法?ES5的元素选择方法是什么?


*getElementById():返回匹配指定ID属性的元素节点.如果没有发现匹配的节点,则返回null.这也是获取一个元素最快的方法;

  • `用setAttribute()方法设置元素属性.

  • getElementsByClassName():返回一个类似数组的对象(HTMLCollection类型的对象),包括了所有class名字符合指定条件的元素(搜索范围包括本身),元素的变化实时反映在返回结果中.这个方法不仅可以在document对象上调用,也可以在任何元素节点上调用;

  • getElementsByTagName():返回所有指定标签的元素(搜索范围包括本身).返回值是一个HTMLCollection对象,也就是说,搜索结果是一个动态集合,任何元素的变化都会实时反映在返回的集合中.这个方法不仅可以在document对象上调用,也可以在任何元素节点上调用;

  • getElementsByName():用于选择拥有name属性的HTML元素,比如form、img、frame、embed和object,返回一个NodeList格式的对象,不会实时反映元素的变化;

  • querySelector():返回匹配指定的CSS选择器的元素节点.如果有多个节点满足匹配条件,则返回第一个匹配的节点.如果没有发现匹配的节点,则返回null;

  • querySelectorAll():返回匹配指定的CSS选择器的所有节点,返回的是NodeList类型的对象.NodeList对象不是动态集合,所以元素节点的变化无法实时反映在返回结果中;

题目4:如何创建一个元素?如何给元素设置属性?如何删除属性


  • 用createElement方法用来生成HTML元素节点.
    var newDiv = document.createElement(“div”);
var node = document.getElementById(“div1”);
node.setAttribute(“my_attrib”, “newVal”);
  • 通过document.createTextNode()来创建文本节点
//1.创建文本节点
var textNode = document.createTextNode('学好前端')
//2.创建一个元素p节点,把文本节点添加到元素p中
var p =document.createElement("p")
p.appendChild(textNode)
//3 在body中显示出创建的元素节点和文本节点
document.getElementByTagName('body')[0].appendChild(p)

题目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 container=document.querySelector('#container');
 var contents=document.querySelector('.content');
 var lists =document.querySelectorAll('.list');
 var paragrah=document.createElement('p');
 var description=document.createTextNode('您好');
 paragraph.appendChild(description);
 containers.appendChild(paragraph);
</script>
</body>
</html>
  • 替换元素replaceChild(),删除元素removeChid().在上述的代码后再加上contents.removeChild(lists[1]);

题目6:element.classList有哪些方法?如何判断一个元素的 class 列表中是包含某个 class?如何添加一个class?如何删除一个class?


element.classList的方法包括:

  • classList.add()用来添加一个class
  • classList.remove()用来删除一个class
  • classList.toggle("visible", i < 10); 添加/删除 visible,取决于测试条件,i小于10
  • classList.contains()用来判断一个元素的class列表中是否包含某个class

题目7: 如何选中如下代码所有的li元素? 如何选中btn元素?


<div class="mod-tabs">
   <ul>
       <li>list1<li>
       <li>list2<li>
       <li>list3<li>
   </ul>
   <button class="btn">点我</btn>
</div>
var li =document.querySelectorAll('.mod-tabs ul li');
console.log(li)
var btn =document.querySelector('.btn');

console.log(btn)

相关文章

  • vip10-dom事件170120

    题目1:dom对象的innerText和innerHTML有什么区别? innerHTML获取元素节点和文本内容....

  • 即时记录170120

    很多事情,很多想法,可能在你心中停留了很久,可是为什么没有去实现呢? 想去看喜欢的歌手的演唱会,可是要去另一个城...

  • 感恩冥想

    170120@D17.感恩冥想 *佩诗* 。深深的感恩慈悲伟大的佛陀 。感恩金刚智慧和慈悲伟大的格西老师教导我们这...

  • 《微课-速读》学习笔记-斌斌

    170120《微课-速读》学习笔记-斌斌 人与人的相遇也许是一次偶然,但分享让你我更有缘,衷心感谢您的阅读~我的朋...

  • 170120——万能钥匙

    《万能钥匙》这部国外电影是上大学时,同宿舍舍友一块看的,时至今日大部分内容已经忘记了,但当看到今天题目时,脑海中马...

  • 养娃日记-170120-纷繁

    对于一个不会说话表达的一岁孩子来说,发烧真的是一件挺挑战的事!既是对孩子的挑战,因为孩子难受需要帮助同时需要表达更...

  • day2.nx170120丹尼

  • day6—xn170120丹尼

  • day3—xn170120丹尼

  • day1—xn170120丹尼

    作业1 3 作业2 作业3

网友评论

      本文标题:vip10-dom事件170120

      本文链接:https://www.haomeiwen.com/subject/esgwbttx.html