事件

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

所谓的0级dom与2级dom事件就是不同版本间的差异,具体的说就是,对于不同的dom级别,在形式上和功能上都是有差异的。

形式上区别:
  • dom0 事件是指定的事件处理程序被认为是元素的方法。
    就是将一个函数赋值给一个事件处理程序属性,(每个元素包括window和document都有自己处理程序的属性)。
    例如: onclick onmouseover onmouseout 等,都是on+type
    这个时候的事件处理程序在元素的作用域中执行。
    ···
    <button id="btn">提交</button>
    <button id="btn2" class="bbb">注册</button>
    ···
var btn= document.getElementById('btn')
btn.onclick= function(){      //DOM0的表示形式     属性名要+ on
  
  console.log('提交成功')
}

提交成功

var btn= document.getElementById('btn2')
btn.addEventListener('click',function(e){    //DOM2的表示形式
   console.log(this)
   console.log(e)
  console.log('注册成功了')
});
<button id="btn2" class="bbb">注册</button>
MouseEvent {isTrusted: true, screenX: 72, screenY: 84, clientX: 72, clientY: 18…}
注册成功了
  • ’DOM2级事件’定义了两个方法,用于处理指定和删除事件处理程序的操作:addEventListener()和removeEventListener();
    所有的DOM节点都包含这两种方法。
    它们都接受3个参数:要处理的事件名,事件处理程序的函数,和一个布尔值。
    最后一个参数:如果为true,表示在捕获阶段调用事件处理程序,如果是false,表示在冒泡阶段调用事件处理程序。
功能上区别:

dom0 是一个函数赋值给一个时间处理程序属性(onclick等),多次赋值后面的会覆盖前面。
dom2 中传递多个参数,调用多次回调函数,添加多个事件,函数不会出现覆盖

参考1
参考2
参考文章

题目2: attachEvent与addEventListener的区别?
区别 attachEvent addEventListener
参数个数不同 有2个参数(函数名称,function(){}) 有3个参数(事件类型,function(){}, true/false)
第一个参数的意义不同 事件处理函数的名称on+type 事件的类型type
事件的作用域不同 全局变量内运行,this->window 元素本身,this->触发元素
一个事件有多个事件处理时的执行顺序不同 无规律顺序 按照添加顺序执行
事件处理阶段 只在冒泡阶段 true ,在捕获阶段处理 ;默认为false ,在冒泡阶段处理
题目3: 解释IE事件冒泡和DOM2事件传播机制?

先解释几个词:

  • 事件: 由用户或浏览器自身执行的某种动作,是某种行为或者触发,比如: 点击click 鼠标滑过mouseover ...

  • javascript 和html就是通过事件实现交互的。

  • 事件处理程序(事件监听器):执行的某种的动作(点击、加载、鼠标等其他行为),响应这个动作(事件)的方法

IE事件冒泡 是 事件开始由具体的元素,逐级向上传播到不具体的元素(由具体到不具体)

DOM2事件传播机制
DOM2级事件规定事件流包含3个阶段:
(1)事件捕获阶段: 由外层不具体的 逐级 向内传播到具体的元素(由外到内)
(2)处于目标阶段 ,事件本身
(3)事件冒泡阶段: 由具体的逐级向外到不具体的元素(由内到外)

事件捕获

事件冒泡
DOM事件流
  • 事件流: 从页面接收事件的顺序。
题目4:如何阻止事件冒泡? 如何阻止默认事件?

阻止事件冒泡
类似中断 ,取消事件冒泡后, 事件不会继续往外传播,外面监听不到
cancelBubble=true用于ie的阻止冒泡事件,
event.stopPropagation()用于firefox和chrome等其他浏览器。

.box{
  background: red;
  width: 200px;
  height: 200px;
}

.box1{
  background: green;
  width: 120px;
  height: 100px;
}

p{
  background: yellow
}
 <div class="box">
    
    <div class="box1">
      
      <p>你好</p>
      
    </div>
    
  </div>
  

var p= document.querySelector('p');
   p.addEventListener('click',function(e){
     
     console.log('p 标签')
     //console.log(e)   //返回事件的相关信息 ,包括事件元素、事件类型等
     
   })
   
 
   
   var box1= document.querySelector('.box1');
   box1.addEventListener('click',function(e){
   
     e.stopPropagation();    //阻止事件冒泡
      console.log('box1  djakd')   
     
   })
   
   var box= document.querySelector('.box');
   box.addEventListener('click',function(){
     
     console.log('box djkah')
     
   })


冒泡的过程: p——>div.box1——> div.box
对box1的事件阻止冒泡后,不会输出 box的内容

输出:
p 标签
 box1  djakd

阻止默认操作
作用是取消一个目标元素的默认行为。
既然是说默认行为,当然是元素必须有默认行为才能被取消,如果元素本身就没有默认行为,调用当然就无效了。
什么元素有默认行为呢?如链接<a>跳转src地址,提交按钮<input type=”submit”>提交form等。
e.preventDefault()用于firefox和chrome等其他浏览器。
IE 则是使用 e.returnValue = false;

首先是默认事件,preventDefault() 才能生效
 <a   id="link" href="baidu.com" >官网</a>
  

 document.querySelector('#link').addEventListener('click',function(e){
              
          e.preventDefault();// 阻止跳转页面
          console.log('没有跳转')
   })
   
效果: 点击链接,没有跳转

输出:
没有跳转
 
题目5:有如下代码,要求当点击每一个元素li时控制台展示该元素的文本内容。不考虑兼容
ul,li{
  
  list-style: none;
  
}
ul{
  border: 1px solid;
  padding: 0;
}
ul li{
  
  border: 1px solid #ccc;
  margin: 8px 2px
}
<ul class="ct">
    <li>这里是</li>
    <li>饥人谷</li>
    <li>前端6班</li>
</ul>
<script>
var ct= document.querySelector('.ct');
   ct.addEventListener('click',function(e){
     
          var b=e.target.innerText;
          console.log(b)
   })
  
</script>

代码

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

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

<ul class="ct">
    <li>这里是</li>
    <li>饥人谷</li>
    <li>任务班</li>
</ul>
<input class="ipt-add-content" placeholder="添加内容"/>
<button id="btn-add-start">开头添加</button>
<button id="btn-add-end">结尾添加</button>
<script>
// 事件代理,添加新的元素,就不用再绑定
var ct= document.querySelector('.ct');
ct.addEventListener('click',function(e){   //e事件对象用来找到目标元素,表示li
        //  console.log(e)
          var b=e.target;                   //target属性: 目标元素(标签)li
          if(b.tagName.toLowerCase()==='li'){//避免点击到li以外的区域,做一个判断,当当前的对象的目标元素是li时,
       
              console.log(b.innerText)        // 输出控制台   目标元素的内容
       
           }
   })
   
   
  var ipt= document.querySelector('.ipt-add-content')
  var btn= document.querySelector('#btn-add-start');

   btn.addEventListener('click',function(){
        
        var li= document.createElement('li');// 添加一个新的li
        
        if(ipt.value.length>0){
           li.innerText= ipt.value;                // 获取输入框的内容给当前的这个li 
                                                //在添加li 到开始位置
           ct.insertBefore(li,ct.firstElementChild);  //添加的新节点,添加的节点位置之前   //ct.firstElementChild  为ul的开头第一个子元素
       }
   })
      
  
  var btn= document.querySelector('#btn-add-end');
      btn.addEventListener('click',function(){
        
       var li= document.createElement('li')
       if(ipt.value.length>0){
          li.innerText= ipt.value;
       
          ct.appendChild(li); 
        
        }
  })
</script>
  

代码

题目7: 补全代码,要求:当鼠标放置在li元素上,会在img-preview里展示当前li元素的data-img对应的图片。
<ul class="ct">
    <li data-img="1.png">鼠标放置查看图片1</li>
    <li data-img="2.png">鼠标放置查看图片2</li>
    <li data-img="3.png">鼠标放置查看图片3</li>
</ul>
<div class="img-preview"></div>
var ct= document.querySelector('.ct');
var images= document.querySelector('.img-preview')

ct.addEventListener('mouseover',function(e){
      var danli=e.target; 
      if(danli.tagName.toLowerCase()==='li'){
   // console.log(this)
      
      var path=danli.getAttribute('data-img')
      
      
     //如果传入的元素是文本的话  可以直接用 innerText传入
     // 但是 如果是图片的话, 没法获取文本  
    // 所以可以用innerHTML=‘可以将这个标签加到HTML中,即而可以运行’
 
   // console.log(path)
    images.innerHTML='![](' + path + ')'
          
   //  console.log(images.innerHTML)
     
     }
})

代码

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

推荐阅读更多精彩内容

  • 1.何谓事件 用户和网页交互时的行为,动作,称之为事件; 2.监视事件 现实生活中,为了监视车辆是否违章,通过在红...
    草鞋弟阅读 567评论 0 0
  • 题目1: DOM0 事件和DOM2级在事件监听使用方式上有什么区别? 事件处理程序 我们也称之为事件侦听器(lis...
    阿鲁提尔阅读 291评论 0 1
  • 1:DOM0事件和DOM2级在事件监听使用方式上有什么区别? 浏览器端的JavaScript采用的是事件驱动的异步...
    饥人谷_bigJiao阅读 265评论 0 0
  • 事件 JavaScript和HTML的交互是通过事件实现的。JavaScript采用异步事件驱动编程模型,当文档、...
    徐国军_plus阅读 545评论 0 2
  • 如何批量操作 css 如何获取 DOM 计算后的样式 使用getComputedStyle获取元素计算后的样式 实...
    _Dot912阅读 535评论 1 3