進(jìn)階9-事件

題目1: DOM0 事件和DOM2級在事件監(jiān)聽使用方式上有什么區(qū)別仗哨?

-DOM0事件監(jiān)聽及使用的本質(zhì)是將事件處理程序(即一個(gè)函數(shù))賦值給一個(gè)節(jié)點(diǎn)的屬性,以達(dá)到操作DOM節(jié)點(diǎn)的目的,通過給屬性賦值的這種方式状勤,由于時(shí)間上后賦值的屬性會覆蓋先賦值的屬性谴仙,因此DOM0的事件處理程序只能有一個(gè)央星。

-DOM2級事件監(jiān)聽及使用本質(zhì)上是對相應(yīng)的節(jié)點(diǎn)執(zhí)行一個(gè)函數(shù),而函數(shù)的數(shù)據(jù)類型為對象传货,也就決定了不同的函數(shù)為不同的對象屎鳍,因此DOM2級事件處理程序可以有很多個(gè)
DOM2級事件定義了兩個(gè)方法用于處理指定和刪除事件處理程序的操作:addEventListener 和 removeEventListener, 所有的DOM節(jié)點(diǎn)都包含這兩個(gè)方法损离,并且它們都接受三個(gè)參數(shù):
事件類型
事件處理方法
布爾參數(shù)哥艇,如果是true表示在捕獲階段調(diào)用事件處理程序,如果是false僻澎,則是在事件冒泡階段處理

題目2: attachEvent與addEventListener的區(qū)別?

DOM2級事件監(jiān)聽及處理程序在IE6十饥、IE6及IE8中并不支持窟勃,但是IE中提供了類似的替代用法,即attachEvent和detachEvent
在添加事件處理程序事addEventListener和attachEvent主要有幾個(gè)區(qū)別

  • 參數(shù)個(gè)數(shù)不相同:addEventListener傳遞參數(shù)(事件類型逗堵,事件處理方法秉氧,布爾值),attachEvent傳遞兩個(gè)參數(shù)(事件蜒秤,處理程序)汁咏,attachEvent添加的事件處理程序只能在冒泡階段發(fā)生,ddEventListener第三個(gè)參數(shù)可以決定添加的事件處理程序是在捕獲階段還是冒泡階段處理(我們一般為了瀏覽器兼容性都設(shè)置為冒泡階段)
  • 第一個(gè)參數(shù)意義不同作媚,addEventListener第一個(gè)參數(shù)是事件類型(比如click攘滩,load),而attachEvent第一個(gè)參數(shù)指明的是事件處理函數(shù)名稱(onclick纸泡,onload)
  • 事件處理程序的作用域不相同漂问,addEventListener的作用域是元素本身,console.log(this)中的this指的是觸發(fā)元素女揭,而attachEvent事件處理程序會在全局變量內(nèi)運(yùn)行蚤假,this是window。
  • 為一個(gè)事件添加多個(gè)事件處理程序時(shí)吧兔,執(zhí)行順序不同:addEventListener添加會按照添加順序執(zhí)行磷仰,而attachEvent添加多個(gè)事件處理程序時(shí)順序無規(guī)律(添加的方法少的時(shí)候大多是按添加順序的反順序執(zhí)行的,但是添加的多了就無規(guī)律了)

題目3: 解釋IE事件冒泡和DOM2事件傳播機(jī)制境蔼?

IE的事件冒泡:事件開始時(shí)由最具體的元素接收灶平,然后逐級向父級元素傳遞,直到傳遞到window
DOM事件流:DOM2級事件規(guī)定事件流包括三個(gè)階段欧穴,事件捕獲階段(事件捕獲與事件冒泡剛好相反民逼,是有window一級一級向子元素進(jìn)行傳遞,直到傳遞至目標(biāo)元素)涮帘,處于目標(biāo)階段拼苍,事件冒泡階段,首先發(fā)生的是事件捕獲,為截取事件提供機(jī)會疮鲫,然后是實(shí)際目標(biāo)接收事件吆你,最后是冒泡階段

題目4:如何阻止事件冒泡? 如何阻止默認(rèn)事件俊犯?

  • stopPropagation()方法可以停止事件在DOM層次的傳播妇多,即取消進(jìn)一步的事件捕獲或冒泡。
  • 要阻止事件的默認(rèn)行為燕侠,可以使用preventDefault()方法者祖,前提是事件的屬性cancelable值為true

題目5:有如下代碼,要求當(dāng)點(diǎn)擊每一個(gè)元素li時(shí)控制臺展示該元素的文本內(nèi)容绢彤。不考慮兼容

  <ul class="ct">
    <li>這里是</li>
    <li>饑人谷</li>
    <li>前端6班</li>
  </ul>
  <script>
     // 方法1
    var ct = document.querySelector('.ct');
    ct.addEventListener('click', function (e) {
      console.log(e.target.innerText);
    });

    // 方法2
    var liNodes =document.querySelectorAll('li')
    liNodes.forEach(function(node) {
      node.addEventListener('click', function(){
        console.log(this.innerText)
      })
    });
  </script>

題目6: 補(bǔ)全代碼七问,要求:

當(dāng)點(diǎn)擊按鈕開頭添加時(shí)在< li>這里是< /li>元素前添加一個(gè)新元素,內(nèi)容為用戶輸入的非空字符串茫舶;當(dāng)點(diǎn)擊結(jié)尾添加時(shí)在最后一個(gè) li 元素后添加用戶輸入的非空字符串.
當(dāng)點(diǎn)擊每一個(gè)元素li時(shí)控制臺展示該元素的文本內(nèi)容械巡。

<ul class="ct">
    <li>這里是</li>
    <li>饑人谷</li>
    <li>任務(wù)班</li>
  </ul>
  <input class="ipt-add-content" placeholder="添加內(nèi)容" />
  <button id="btn-add-start">開頭添加</button>
  <button id="btn-add-end">結(jié)尾添加</button>
  <script>
    var addStart = document.querySelector('#btn-add-start')
    var addEnd = document.querySelector('#btn-add-end')
    var iptContent = document.querySelector('.ipt-add-content')
    var container = document.querySelector('ul')
    console.log(container)
    container.addEventListener('click', function (e) {
      console.log(e.target.innerText)
    })
    addStart.addEventListener('click', function () {
      if (iptContent.value !== '') {
        var node = document.createElement('li')
        node.innerText = iptContent.value
        container.insertBefore(node, container.firstChild)
      }
    })
    addEnd.addEventListener('click', function () {
      if (iptContent.value !== '') {
      var node = document.createElement('li')
      node.innerText = iptContent.value
      container.appendChild(node)
      }
    })
  </script>

題目7: 補(bǔ)全代碼,要求:當(dāng)鼠標(biāo)放置在li元素上饶氏,會在img-preview里展示當(dāng)前l(fā)i元素的data-img對應(yīng)的圖片讥耗。


  <ul class="ct">
    <li data-img="http://cdn.jirengu.com/book.jirengu.com/img/11.jpg">鼠標(biāo)放置查看圖片1</li>
    <li data-img="http://cdn.jirengu.com/book.jirengu.com/img/13.jpg">鼠標(biāo)放置查看圖片2</li>
    <li data-img="http://cdn.jirengu.com/book.jirengu.com/img/14.jpg">鼠標(biāo)放置查看圖片3</li>
  </ul>
  <div class="img-preview"></div>
  <script>
    // 方法1
    var liNodes = document.querySelectorAll('li');
    var preview = document.querySelector('.img-preview');

    for (var i = 0; i < liNodes.length; i++) {
      liNodes[i].addEventListener('mouseenter', function () {
        var dataImg = this.getAttribute('data-img');
        preview.innerHTML = '![](' + dataImg + ')'
      });
    }

    //方法2

    // var ct = document.querySelector('.ct')
    // console.log(ct)
    // var imgPre = document.querySelector('.img-preview')
    // console.log(imgPre)
    // ct.addEventListener('mouseover', function (e) {
    //   var path = e.target.getAttribute('data-img');
    //   console.log(path)
    //   imgPre.innerHTML = '![](' + path + ')'
    // })
  </script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市疹启,隨后出現(xiàn)的幾起案子古程,更是在濱河造成了極大的恐慌,老刑警劉巖皮仁,帶你破解...
    沈念sama閱讀 207,113評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件籍琳,死亡現(xiàn)場離奇詭異,居然都是意外死亡贷祈,警方通過查閱死者的電腦和手機(jī)趋急,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來势誊,“玉大人呜达,你說我怎么就攤上這事∷诔埽” “怎么了查近?”我有些...
    開封第一講書人閱讀 153,340評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長挤忙。 經(jīng)常有香客問我霜威,道長,這世上最難降的妖魔是什么册烈? 我笑而不...
    開封第一講書人閱讀 55,449評論 1 279
  • 正文 為了忘掉前任戈泼,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘大猛。我一直安慰自己扭倾,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評論 5 374
  • 文/花漫 我一把揭開白布挽绩。 她就那樣靜靜地躺著膛壹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪唉堪。 梳的紋絲不亂的頭發(fā)上模聋,一...
    開封第一講書人閱讀 49,166評論 1 284
  • 那天,我揣著相機(jī)與錄音巨坊,去河邊找鬼撬槽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛趾撵,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播共啃,決...
    沈念sama閱讀 38,442評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼占调,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了移剪?” 一聲冷哼從身側(cè)響起究珊,我...
    開封第一講書人閱讀 37,105評論 0 261
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎纵苛,沒想到半個(gè)月后剿涮,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡攻人,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評論 2 325
  • 正文 我和宋清朗相戀三年取试,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片怀吻。...
    茶點(diǎn)故事閱讀 38,161評論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡瞬浓,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蓬坡,到底是詐尸還是另有隱情猿棉,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評論 4 323
  • 正文 年R本政府宣布屑咳,位于F島的核電站萨赁,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏兆龙。R本人自食惡果不足惜杖爽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧掂林,春花似錦臣缀、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至锣杂,卻和暖如春脂倦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背元莫。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評論 1 261
  • 我被黑心中介騙來泰國打工赖阻, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人踱蠢。 一個(gè)月前我還...
    沈念sama閱讀 45,618評論 2 355
  • 正文 我出身青樓火欧,卻偏偏與公主長得像,于是被迫代替她去往敵國和親茎截。 傳聞我的和親對象是個(gè)殘疾皇子苇侵,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評論 2 344

推薦閱讀更多精彩內(nèi)容