亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JS和JQ的event對象區別分析

2019-11-20 13:53:14
字體:
來源:轉載
供稿:網友

代碼測試:

復制代碼 代碼如下:

<div id="test"><p>test text<p></div>
<script src="vendor/jquery-2.1.1.js"></script>
<script>
test.addEventListener('click', function(e){console.log(e);}, false),
$('#test').on('click', function(e){console.log(e)});
</script>

結果分析:

復制代碼 代碼如下:

js-jq-event-common:{
  altKey: false,
  bubbles: true,
  button: 0,
  cancelable: true,
  clientX: 58,
  clientY: 13,
  ctrlKey: false,
  offsetX: 50,
  offsetY: 5,
  pageX: 58,
  pageY: 13,
  screenX: 58,
  screenY: 122,
  view: Window,
  which: 1,
  type: 'click',
  timeStamp: 1407761742842,
  metaKey: false,
  relatedTarget: null,
  target: div#test /*jq-evt的target不一定是jQuery選擇器匹配的元素,可能是第一個捕獲事件的元素,然后向上冒泡時其中一個才是選擇器匹配的元素*/
},
 js-jq-event-diff:{
  currentTarget: null/*貌似一般都為null*/
              || div#test/*jq選擇器匹配的元素在[currentTarget]屬性*/,
  eventPhase: 0 || 2,
  toElement: div#test
},
 js-event-solo:{
  x: 58,
  y: 13,
  cancelBubble: false,
  charCode: 0,
  clipboardData: undefined,
  dataTransfer: null,
  defaultPrevented: false,
  srcElement: div#test,
  fromElement: null,
  detail: 1,
  keyCode: 0,
  layerX: 58,
  layerY: 13,
  returnValue: true
},
 jq-event-solo: {
  buttons: undefined,
  data: undefined,
  delegateTarget: div#test/*誰在監聽?就是這個元素啦。*/,
  isDefaultPrevented: function,
  handleObj: Object,
  jQuery211024030584539286792: true,
  originalEvent: MouseEvent,
  shiftKey: false
}
 body-click-delegate-event: {
  currentTarget: HTMLBodyElement,
  delegateTarget: HTMLBodyElement,
  target: HTMLDivElement
}

總結:

js的event參數中,不管是target, toElement, srcElement都是指向第一個觸發事件的元素(還沒冒泡),而fromElement在click事件中為null,所以,你如果是設置包含很多元素的父容器parent事件,那么觸發事件的很可能是這個parent的子元素。
因此,在實際應用中,如果要引用parent,那你只能使用this了
jq的event參數中,
currentTarget是匹配你選擇器的元素,就是你的所要元素;
delegateTarget是在監聽事件的元素,屬于被委托的元素
target同js的event參數里的target,是第一個觸發事件的元素,沒currentTarget有用(也不一定,比如在bodyclick事件中的應用)
有同學可能說,你要直接引用被設備事件的元素用this就得啦,何必理解currentTarget和target呢。這個想法證明你還只是用下jQuery而已,沒用過類似Backbone之類的工具。

Backbone很多地方綁定了this,所以在它的函數中用this是不行的:

復制代碼 代碼如下:

var view = Backbone.View.extend({
  el: document.body,
   events: {
    'click p': 'showText'     // 委托body監聽p的click事件   },
   showText: function(e){
    var p = e.currentTarget;  // [currentTarget]獲取選擇器匹配的元素     this.log(p.innerHTML);    // 看到了吧,this并不指向p元素   },
   log: function(msg){
    console.log(msg);
  }
});

雖然JS,JQ中event對象大同小異,但還是有些許區別的,大家是否了解了呢

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩美女免费线视频| 亚洲999一在线观看www| 国产亚洲精品美女久久久久| 久久九九国产精品怡红院| 久久久精品久久久| 色无极影院亚洲| 久久777国产线看观看精品| 久久久免费观看视频| 欧美视频不卡中文| 国产午夜精品一区理论片飘花| 深夜成人在线观看| 永久免费毛片在线播放不卡| 国产精品免费一区| 91久久久久久国产精品| 成人激情综合网| 国产一区二区三区网站| 98视频在线噜噜噜国产| 亚洲精品美女久久久久| 亚洲人成毛片在线播放| 亚洲精品国精品久久99热| 热久久免费视频精品| 555www成人网| 精品国产区一区二区三区在线观看| 最近2019中文字幕大全第二页| 国产精品久久久久久久久免费看| 91精品视频大全| 欧美极品少妇xxxxⅹ免费视频| 成人淫片在线看| 国产精品丝袜一区二区三区| 欧美日韩午夜剧场| 91亚洲精品一区| 国产精品久久久久久av| 国产在线久久久| 亚洲视频电影图片偷拍一区| 亚洲精选一区二区| 欧美性猛交99久久久久99按摩| 亚洲黄页视频免费观看| 日本不卡高字幕在线2019| 日韩美女免费视频| 91中文字幕一区| 欧美日韩国产中文精品字幕自在自线| 有码中文亚洲精品| 欧美一级电影久久| 正在播放欧美视频| 亚洲第一区在线| 91久久夜色精品国产网站| 国产欧美一区二区三区久久人妖| 97欧美精品一区二区三区| 久久精品国产亚洲精品| 久久九九亚洲综合| 亚洲男人天堂手机在线| 欧美午夜久久久| 国产网站欧美日韩免费精品在线观看| 91豆花精品一区| 亚洲第一男人天堂| 亚洲国产欧美一区二区三区同亚洲| 亚洲一区二区三区xxx视频| 91免费综合在线| 色综合色综合久久综合频道88| 亚洲高清不卡av| 久久久成人av| 91久久国产婷婷一区二区| 日韩福利视频在线观看| 亚洲欧美自拍一区| 国产99在线|中文| 亚洲跨种族黑人xxx| 亚洲精品久久久久久久久久久久| 亚洲qvod图片区电影| 亚洲国产精品va| 久久精彩免费视频| 精品香蕉在线观看视频一| 成人免费视频网址| 一道本无吗dⅴd在线播放一区| 亚洲第一中文字幕| 亚洲欧洲美洲在线综合| 91干在线观看| 97在线视频观看| 高清欧美性猛交| 日韩在线欧美在线国产在线| 欧美成人中文字幕在线| 亚洲第一级黄色片| 欧美极品少妇xxxxⅹ免费视频| 日韩精品小视频| 欧美久久精品一级黑人c片| 美日韩丰满少妇在线观看| 欧美一级片久久久久久久| 久久激情五月丁香伊人| 91精品国产成人| 国产成一区二区| 国产成人精品视频在线| 久久999免费视频| 中文字幕亚洲一区二区三区| 日本免费一区二区三区视频观看| 国产精品综合久久久| 热re99久久精品国产66热| 精品久久久国产| 亚洲电影在线看| 97国产精品免费视频| 日韩精品极品视频| 久久亚洲精品毛片| 26uuu久久噜噜噜噜| 91在线观看免费高清完整版在线观看| 在线视频精品一| 精品视频在线播放| 日韩高清免费观看| 亚洲一区二区三区sesese| 性夜试看影院91社区| 日韩av在线一区二区| 日韩二区三区在线| 国产成人免费91av在线| 国产综合视频在线观看| 国产精品亚洲激情| 久久的精品视频| 欧美精品在线网站| 亚洲精品视频免费| 成人福利视频在线观看| 国产精品黄色影片导航在线观看| 91社区国产高清| 97av视频在线| 日韩福利视频在线观看| 亚洲白虎美女被爆操| 大胆人体色综合| 欧美中文在线视频| 欧美激情精品久久久久| 日韩大陆欧美高清视频区| 97精品国产aⅴ7777| 国产精品亚洲视频在线观看| 日韩电影免费观看在线观看| 亚洲男人第一av网站| 日韩在线播放一区| 国产亚洲一级高清| 久久中文精品视频| 97超级碰碰人国产在线观看| 亚洲在线免费视频| 高清视频欧美一级| 另类天堂视频在线观看| 精品人伦一区二区三区蜜桃网站| 国产91精品青草社区| 国产成人综合亚洲| 国产精品免费观看在线| 欧美午夜丰满在线18影院| 亚洲美女性视频| 美女精品久久久| 欧美视频在线视频| 成人在线一区二区| 欧美丝袜一区二区三区| 伊人久久久久久久久久| 成人激情春色网| 日韩av影视在线| 久久综合久久88| 午夜精品久久久久久久99热浪潮| 国产精品一区二区三| 欧美激情精品久久久久久变态| 亚洲人成网站免费播放| 精品国产成人av| 精品成人久久av| 成人a免费视频| 亚洲色图偷窥自拍| 日韩理论片久久| 国产成人av在线| 好吊成人免视频| 国产精品电影一区| 久久精品国产v日韩v亚洲| 国产精品av免费在线观看|