Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

JavaScript事件 #29

Open
zhnd opened this issue Mar 2, 2018 · 0 comments
Open

JavaScript事件 #29

zhnd opened this issue Mar 2, 2018 · 0 comments
Labels
study note My learning record

Comments

@zhnd
Copy link
Owner

zhnd commented Mar 2, 2018

小练习:

题目1:DOM0事件和DOM2级在事件监听使用方式上有什么区别?

DOM0级

Dom0级事件处理程序是将一个函数赋值给一个事件处理程序属性,要使用JavaScript指定事件处理程序,首先要获得一个要操作的对象的引用,然后通过其事件处理程序属性(这些属性通常全部小写,例如:onclick),指定事件处理程序。

 var btn = document.getElementById('myBtn');
 btn.onclick = function() {
   console.log(this.id);
 };

如果需要删除DOM0级事件处理程序,只需将相应属性值设置为null。

btn.onclick = null;
  • 优点:简单且跨浏览器;
  • 缺点:一个事件处理程序只能对应一个处理函数,给一个事件添加多个事件处理程序,后面的程序会覆盖前面的程序。
DOM2级

DOM2级事件定义了两个方法用于处理指定和删除事件处理程序的操作:

  1. addEventListener
  2. removeEventListener

所有的DOM节点都包含这两个方法,并且它们都接受三个参数:

  1. 事件类型
  2. 事件处理方法
  3. 布尔参数,如果是true表示在捕获阶段调用事件处理程序,如果是false,则是在事件冒泡阶段处理程序。
 var btn = document.getElementById('myBtn');
 var handler = function() {
   console.log(this.id);
 };

 // 添加事件处理程序
 btn.addEventListener('click', handler, false);

 // 删除事件处理程序
 btn.removeEventListener('click', handler, false);
  • 优点:能够实现同时绑定多个事件而不覆盖;
  • 缺点:IE并不支持addEventListenerremoveEventListener方法。

题目2:attachEvent与addEventListener的区别?

  1. 参数个数不相同,这个最直观,addEventListener有三个参数,attachEvent只有两个,attachEvent添加的事件处理程序只能发生在冒泡阶段,addEventListener第三个参数可以决定添加的事件处理程序是在捕获阶段还是冒泡阶段处理(我们一般为了浏览器兼容性都设置为冒泡阶段)

  2. 第一个参数意义不同,addEventListener第一个参数是事件类型(比如clickload),而attachEvent第一个参数指明的是事件处理函数名称(onclickonload

  3. 事件处理程序的作用域不相同,addEventListener的作用域是元素本身,this是指的触发元素,而attachEvent事件处理程序会在全局变量内运行,thiswindow,所以刚才例子才会返回undefined,而不是元素id

  4. 为一个事件添加多个事件处理程序时,执行顺序不同,addEventListener添加会按照添加顺序执行,而attachEvent添加多个事件处理程序时顺序无规律(添加的方法少的时候大多是按添加顺序的反顺序执行的,但是添加的多了就无规律了),所以添加多个的时候,不依赖执行顺序的还好,若是依赖于函数执行顺序,最好自己处理,不要指望浏览器。

题目3:解释IE事件冒泡和DOM2事件传播机制?

  • IE的事件冒泡

事件开始时由最具体的元素接收,然后逐级向上传播到较为不具体的元素;

IE bubble

  • DOM事件流

DOM2级事件规定事件流包括三个阶段,事件捕获阶段,处于目标阶段,事件冒泡阶段,首先发生的是事件捕获,为截取事件提供机会,然后是实际目标接收事件,最后是冒泡阶段。

DOM2 bubble

题目4:如何阻止事件冒泡? 如何阻止默认事件?

  • 阻止事件捕获、冒泡:
event.stopPropagation();
  • 阻止事件默认行为:
event.preventDefault();
  • 阻止冒泡的兼容写法,值为false为允许冒泡:
event.cancelBubble = true;

event.cancelBubble = false;
  • 阻止默认事件的兼容写法,值为flase为允许默认事件:
event.returnValue = true;

event.returnValue = false;

题目5:有如下代码,要求当点击每一个元素li时控制台展示该元素的文本内容。不考虑兼容

 <ul class="ct">
   <li>Hello</li>
   <li>World</li>
   <li>!</li>
 </ul>
 var ct = document.querySelector('.ct');
 ct.addEventListener('click', function(e) {
   if (e.target.tagName.toLowerCase() === 'li') {
     console.log(e.target.innerText);
   }
 }, false);

题目6:补全代码,要求:

当点击按钮开头添加时在<li>这里是</li>元素前添加一个新元素,内容为用户输入的非空字符串;当点击结尾添加时在最后一个 li 元素后添加用户输入的非空字符串.
当点击每一个元素li时控制台展示该元素的文本内容。

  <ul class="ct">
    <li>Hello</li>
    <li>World</li>
    <li>!</li>
  </ul>
  <input id="input-content" placeholder="please input content" type="text">
  <button id="btn-add-start">开头添加</button>
  <button id="btn-add-end">结尾添加</button>
  var ct = document.querySelector('.ct'),
    addStartBtn = document.querySelector('#btn-add-start'),
    addEndBtn = document.querySelector('#btn-add-end'),
    inputContent = document.querySelector('#input-content');

  ct.addEventListener('click', function(e) {
    if (e.target.tagName.toLowerCase() === 'li') {
      console.log(e.target.innerText);
    }
  });

  addStartBtn.addEventListener('click', function(e) {
    if (/^\s*$/.test(inputContent.value)) {
      console.log('输入的是空字符串');
    } else {
      var li = document.createElement('li');
      li.innerText = inputContent.value;
      ct.insertBefore(li, ct.firstChild);
    }
  }, false);

  addEndBtn.addEventListener('click', function(e) {
    if (/^\s*$/.test(inputContent.value)) {
      console.log('输入的是空字符串');
    } else {
      var li = document.createElement('li');
      li.innerText = inputContent.value;
      ct.appendChild(li);
    }
  }, false);

题目7: 补全代码,要求:当鼠标放置在li元素上,会在img-preview里展示当前li元素的data-img对应的图片。

  <ul class="ct">
    <li data-img="https://raw.githubusercontent.com/z2x/blog/master/images/people-sea.jpg">鼠标放置查看图片1</li>
    <li data-img="https://raw.githubusercontent.com/z2x/blog/master/images/Sky-background.jpg">鼠标放置查看图片2</li>
    <li data-img="https://raw.githubusercontent.com/z2x/blog/master/images/sky-sea-finish.jpg">鼠标放置查看图片3</li>
  </ul>
  <div class="img-preview"></div>
  var ul = document.querySelector('.ct');
  var imgPreview = document.querySelector('.img-preview');
  ul.addEventListener('mouseover', function(e) {
    if (e.target.tagName.toLowerCase() === 'li') {
      var img = e.target.getAttribute('data-img');
      imgPreview.innerHTML = '<img src = "' + img + '">';
    }
  }, false);
@zhnd zhnd added the study note My learning record label Mar 2, 2018
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
study note My learning record
Projects
None yet
Development

No branches or pull requests

1 participant