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

首頁 > 編程 > JavaScript > 正文

js事件監(jiān)聽機制(事件捕獲)總結

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

在前端開發(fā)過程中我們經常會遇到給頁面元素添加事件的問題,添加事件的js方法也很多,有直接加到頁面結構上的,有使用一些js事件監(jiān)聽的方法,由于各個瀏覽器對事件冒泡事件監(jiān)聽的機制不同,le瀏覽器只有事件冒泡,沒有事件監(jiān)聽的機制,對于事件監(jiān)聽的兼容性問題是最大的難題:

1.直接把事件的方法寫在頁面結構上

function eventfun(){ //console.log(this); } <input type="button" onclick="eventfun()" value="button" />//這里涉及到一個this作用域的問題,eventfun再這里是一個全局函數, 對象是[object Window],this指向的是window.

要解決this作用域的問題,可以使用為全局函數添加event變量的方法,在頁面結構上將this對象作為參數傳遞到函數內部使用

<input type="button" onclick="eventfun2(this)" value="button2" /> function eventfun2(eve){//在這里把事件對象作為參數傳遞到全局方法里 eve.name="alex"; window.name="robin"; console.log(this);//[object Window] console.log(eve);// [object HTMLInputElement] console.log(this.name);// robin console.log(eve.name);// alexvar self=eve; console.log(this.name);//robin console.log(self.name);//alex alert(window.name); alert(self.name); }

2. 使用給事件屬性賦值的方法,是一種為事件綁定的方法,但是這種方法的局限性就是只能為事件綁定一個方法,如果綁定多個就會以后一個方法為準

HTMLElementobject.onclick = fucntion(){//使用這種為事件屬性賦值的方法,this的指針會指向window對象,而不是被事件對象,所以這種方法是引用

//js code fun1(); fun2(); fun3(); console.log(this);//window.object } function dosomething(){ //js code } HTMLElementobject.onclick = dosomething;//使用這種為事件對象屬性賦值的形式,this指針指向事件執(zhí)行對象 console.log(this);//htmlElementObject

3.事件傳播――冒泡與捕獲
DOM事件標準定義了兩種事件流,這兩種事件流有著顯著的不同并且可能對你的應用有著相當大的影響。這兩種事件流分別是捕獲和冒泡。和許多Web技 術一樣,在它們成為標準之前,Netscape和微軟各自不同地實現了它們。Netscape選擇實現了捕獲事件流,微軟則實現了冒泡事件流。幸運的 是,W3C決定組合使用這兩種方法,并且大多數新瀏覽器都遵循這兩種事件流方式。
默認情況下,事件使用冒泡事件流,不使用捕獲事件流。然而,在Firefox和Safari里,你可以顯式的指定使用捕獲事件流,方法是在注冊事件時傳入useCapture參數,將這個參數設為true。
冒泡事件流
當事件在某一DOM元素被觸發(fā)時,例如用戶在客戶名字節(jié)點上點擊鼠標,事件將跟隨著該節(jié)點繼承自的各個父節(jié)點冒泡穿過整個的DOM節(jié)點層次,直到它 遇到依附有該事件類型處理器的節(jié)點,此時,該事件是onclick事件。在冒泡過程中的任何時候都可以終止事件的冒泡,在遵從W3C標準的瀏覽器里可以通 過調用事件對象上的stopPropagation()方法,在Internet Explorer里可以通過設置事件對象的cancelBubble屬性為true。如果不停止事件的傳播,事件將一直通過DOM冒泡直至到達文檔根。
捕獲事件流
事件的處理將從DOM層次的根開始,而不是從觸發(fā)事件的目標元素開始,事件被從目標元素的所有祖先元素依次往下傳遞。在這個過程中,事件會被從文檔 根到事件目標元素之間各個繼承派生的元素所捕獲,如果事件監(jiān)聽器在被注冊時設置了useCapture屬性為true,那么它們可以被分派給這期間的任何 元素以對事件做出處理;否則,事件會被接著傳遞給派生元素路徑上的下一元素,直至目標元素。事件到達目標元素后,它會接著通過DOM節(jié)點再進行冒泡。
現代事件綁定方法
針對如上節(jié)課所討論的,使用傳統(tǒng)事件綁定有許多缺陷,比如不能在一個對象的相同事件上注冊多個事件處理函數。而瀏覽器和W3C也并非沒有考慮到這一點,因此在現代瀏覽器中,它們有自己的方法綁定事件。
W3C DOM
obj.addEventListener(evtype,fn,useCapture)――W3C提供的添加事件處理函數的方法。obj是要添 加事件的對象,evtype是事件類型,不帶on前綴,fn是事件處理函數,如果useCapture是true,則事件處理函數在捕獲階段被執(zhí)行,否則 在冒泡階段執(zhí)行
obj.removeEventListener(evtype,fn,useCapture)――W3C提供的刪除事件處理函數的方法
微軟IE方法
obj.attachEvent(evtype,fn)――IE提供的添加事件處理函數的方法。obj是要添加事件的對象,evtype是事件類型,帶on前綴,fn是事件處理函數,IE不支持事件捕獲
obj.detachEvent(evtype,fn,)――IE提供的刪除事件處理函數的方法,evtype包含on前綴

整合兩者的方法

function addEvent(obj,evtype,fn,useCapture) { if (obj.addEventListener) { obj.addEventListener(evtype,fn,useCapture); } else { obj.attachEvent("on"+evtype,fn);//IE不支持事件捕獲 } else { obj["on"+evtype]=fn;//事實上這種情況不會存在 } } function delEvent(obj,evtype,fn,useCapture) { if (obj.removeEventListener) { obj.removeEventListener(evtype,fn,useCapture); } else { obj.detachEvent("on"+evtype,fn); } else { obj["on"+evtype]=null; } }

IE的attach方法有個問題,就是使用attachEvent時在事件處理函數內部,this指向了window,而不是obj!當然,這個是有解決方案的!

但IE的attachEvent方法有另外一個問題,同一個函數可以被注冊到同一個對象同一個事件上多次,解決方法:拋棄IE的 attachEvent方法吧!IE下的attachEvent方法不支持捕獲,和傳統(tǒng)事件注冊沒多大區(qū)別(除了能綁定多個事件處理函數),并且IE的 attachEvent方法存在內存泄漏問題!
addEvent,delEvent現代版

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>js事件監(jiān)聽</title> <style> table td{font:12px; border-bottom:1px solid #efefef;} </style> </head> <body> <div id="outEle" style="padding:10px; border:1px solid #b2b2b2; background:#efefef;"> <input type="button" onclick="eventfun()" id="button" value="button" /><br /> <input type="button" onclick="eventfun2(this);" id="button2" value="button2" /><br /> <input type="button" id="button3" value="button3" /><br /> <input type="button" id="button4" value="button4" /><br /> <table id="htmlEleTable" width="100%" border="0" style="border:1px solid #b2b2b2; background:#fff;"> <tr id="1111"><td>111111111111111111111111111111</td></tr> <tr id="22222"><td>222222222222222222222222222222</td></tr> <tr id="33333"><td>333333333333333333333333333333</td></tr> <tr id="4444"><td>444444444444444444444444444444</td></tr> <tr id="55555"><td>555555555555555555555555555555</td></tr> </table> </div> <script language="javascript" type="text/javascript"> function eventfun(){//1.直接把js方法寫在頁面結構上 console.log(this);//這里涉及到一個this作用域的問題,eventfun再這里是一個全局函數, 對象是window,this指向的是window alert(this); } function eventfun2(eve){//在這里把事件對象作為參數傳遞到全局方法里 eve.name="alex";// window.name="robin"; console.log(this);//[object Window] console.log(eve);// [object HTMLInputElement] console.log(this.name);// robin console.log(eve.name);// alex var self=eve; console.log(this.name);//robin console.log(self.name);//alex alert(window.name); alert(self.name); } function eventfun3(){//1.直接把js方法寫在頁面結構上 console.log(this);//這里涉及到一個this作用域的問題,eventfun再這里是一個全局函數, 對象是window,this指向的是window console.log(this.id); alert(this); alert(this.id); //var outEleObj = EventUtil.$("outEle"); //removeEvent(outEleObj,"click",eventfun3); } /* var EventUtil = {}; EventUtil.$ = function(id){ return document.getElementById(id); } EventUtil.openmes = eventfun3; EventUtil.addEventHandle = function(eventTarget,eventtype,eventHandle){//定義事件監(jiān)聽的對象元素,事件類型,事件函數 if(eventTarget.attachEvent){ eventTarget.attachEvent("on"+eventtype,eventHandle); }else if(eventTarget.addEventListener){ eventTarget.addEventListener(eventtype,eventHandle,false) }else{ eventTarget["on" + eventtype] = null; } }; EventUtil.deleEventHandle = function(eventTarget,eventtype,eventHandle){//定義事件監(jiān)聽的對象元素,事件類型,事件函數 if(eventTarget.detachEvent){ alert("on"+eventtype); alert("on"+eventHandle); eventTarget.detachEvent("on"+eventtype,eventHandle); }else if(eventTarget.removeEventListener){ eventTarget.removeEventListener(eventtype,eventHandle,false) }else{ eventTarget["on" + eventtype] = null; } };*/ var EventUtil={ $:function(id){ return document.getElementById(id); }, but4fun:function(){ console.log(this); this.addEventHandle(); }, eventfun3:function (){ console.log(this); alert(this); delEvent(obj,evtype,fn,useCapture); } } /***使用addEventListener,attachEvent進行dom事件的監(jiān)聽 function addEvent(obj,evtype,fn,useCapture){ if (obj.addEventListener) { obj.addEventListener(evtype,fn,useCapture); }else if(obj.attachEvent){ obj.attachEvent("on"+evtype,function () { fn.call(obj); }); }else { obj["on"+evtype]=fn;//事實上這種情況不會存在 } } function delEvent(obj,evtype,fn,useCapture) { if (obj.removeEventListener) { obj.removeEventListener(evtype,fn,useCapture); } else if(obj.detachEvent){ obj.detachEvent("on"+evtype,fn); } else { obj["on"+evtype]=null; } } function addEvent(obj,evtype,fn,useCapture) { if (obj.addEventListener) {//優(yōu)先考慮W3C事件注冊方案 obj.addEventListener(evtype,fn,!!useCapture); } else {//當不支持addEventListener時(IE),由于IE同時也不支持捕獲,所以不如使用傳統(tǒng)事件綁定 if (!fn.__EventID) {fn.__EventID = addEvent.__EventHandlesCounter++;} //為每個事件處理函數分配一個唯一的ID if (!obj.__EventHandles) {obj.__EventHandles={};} //__EventHandles屬性用來保存所有事件處理函數的引用 //按事件類型分類 if (!obj.__EventHandles[evtype]) {//第一次注冊某事件時 obj.__EventHandles[evtype]={}; if (obj["on"+evtype]) {//以前曾用傳統(tǒng)方式注冊過事件處理函數 (obj.__EventHandles[evtype][0]=obj["on"+evtype]).__EventID=0;//添加到預留的0位 //并且給原來的事件處理函數增加一個ID } obj["on"+evtype]=addEvent.execEventHandles; //當事件發(fā)生時,execEventHandles遍歷表obj.__EventHandles[evtype]并執(zhí)行其中的函數 } } } addEvent.__EventHandlesCounter=1;//計數器,0位預留它用 addEvent.execEventHandles = function (evt) {//遍歷所有的事件處理函數并執(zhí)行 if (!this.__EventHandles) {return true;} evt = evt || window.event; var fns = this.__EventHandles[evt.type]; for (var i in fns) { fns[i].call(this); } }; /* function delEvent(obj,evtype,fn,useCapture) { if (obj.removeEventListener) {//先使用W3C的方法移除事件處理函數 obj.removeEventListener(evtype,fn,!!useCapture); } else { if (obj.__EventHandles) { var fns = obj.__EventHandles[evtype]; if (fns) {delete fns[fn.__EventID];} } } } function fixEvent(evt) {//fixEvent函數不是單獨執(zhí)行的,它必須有一個事件對象參數,而且只有事件發(fā)生時它才被執(zhí)行!最好的方法是把它整合到addEvent函數的execEventHandles里面 if (!evt.target) { evt.target = evt.srcElement; evt.preventDefault = fixEvent.preventDefault; evt.stopPropagation = fixEvent.stopPropagation; if (evt.type == "mouseover") { evt.relatedTarget = evt.fromElement; } else if (evt.type =="mouseout") { evt.relatedTarget = evt.toElement; } evt.charCode = (evt.type=="keypress")?evt.keyCode:0; evt.eventPhase = 2;//IE僅工作在冒泡階段 evt.timeStamp = (new Date()).getTime();//僅將其設為當前時間 } return evt; } fixEvent.preventDefault =function () { this.returnValue = false;//這里的this指向了某個事件對象,而不是fixEvent }; fixEvent.stopPropagation =function () { this.cancelBubble = true; };*/ //console.log(EventUtil.$("button3"));//返回EventUtil函數的對象屬性 //EventUtil.$("button3").onclick= eventfun;//2.使用為對象事件屬性賦值的方法來實現事件的監(jiān)聽 //EventUtil.$("button3").onclick= eventfun2;//為事件屬性添加多個方法時,為后者 //EventUtil.$("button3").onclick= eventfun;//事件捕獲是從事件對象逐層外父級檢察一直到window對象 var EventUtil =function(){ function getByid(id){ return document.getElementById(id); }; // written by Dean Edwards, 2005 // with input from Tino Zijdel, Matthias Miller, Diego Perini // http://dean.edwards.name/weblog/2005/10/add-event/ function addEvent(element, type, handler) { if (element.addEventListener) { element.addEventListener(type, handler, false); } else { // assign each event handler a unique ID if (!handler.$$guid) handler.$$guid = addEvent.guid++; // create a hash table of event types for the element if (!element.events) element.events = {}; // create a hash table of event handlers for each element/event pair var handlers = element.events[type]; if (!handlers) { handlers = element.events[type] = {}; // store the existing event handler (if there is one) if (element["on" + type]) { handlers[0] = element["on" + type]; } } // store the event handler in the hash table handlers[handler.$$guid] = handler; // assign a global event handler to do all the work element["on" + type] = handleEvent; } }; // a counter used to create unique IDs addEvent.guid = 1; function removeEvent(element, type, handler) { if (element.removeEventListener) { element.removeEventListener(type, handler, false); } else { // delete the event handler from the hash table if (element.events && element.events[type]) { delete element.events[type][handler.$$guid]; } } }; function handleEvent(event) { var returnValue = true; // grab the event object (IE uses a global event object) event = event || fixEvent(((this.ownerDocument || this.document || this).parentWindow || window).event); // get a reference to the hash table of event handlers var handlers = this.events[event.type]; // execute each event handler for (var i in handlers) { this.$$handleEvent = handlers[i]; if (this.$$handleEvent(event) === false) { returnValue = false; } } return returnValue; }; function fixEvent(event) { // add W3C standard event methods event.preventDefault = fixEvent.preventDefault; event.stopPropagation = fixEvent.stopPropagation; return event; }; fixEvent.preventDefault = function() { this.returnValue = false; }; fixEvent.stopPropagation = function() { this.cancelBubble = true; }; function tableAddEvent(){ }; return{ add:addEvent, remove:removeEvent, $:getByid } }(); var outEleObj = EventUtil.$("outEle"); //addEvent.apply(EventUtil,[outEleObj,"click",eventfun3]); //EventUtil.add(outEleObj,"click",eventfun3); var inputObj = EventUtil.$("button4"); var tableEle = EventUtil.$("htmlEleTable"); var tabTrEle = tableEle.getElementsByTagName("tr"); EventUtil.add(tableEle,"click",eventfun3); for (i=0; i<tabTrEle.length; i++){ EventUtil.add(tabTrEle[i],"click",eventfun3); } EventUtil.remove(tableEle,"click",eventfun3);//事件冒刪除方法 EventUtil.add(tableEle,"click",eventfun3);//事件冒泡添加方法 //EventUtil.add(inputObj,"click",eventfun3); //EventUtil.remove(outEleObj,"click",eventfun3); //console.log(addEvent); //addEvent(inputObj,"click",eventfun3,true); //delEvent(outEleObj,"click",eventfun3,false); </script> </body> </html>

PS:這里再為大家提供一個關于JS事件的在線工具,歸納總結了JS常用的事件類型與函數功能:

javascript事件與功能說明大全:

http://tools.VeVB.COm/table/javascript_event

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
成年人在线视频免费观看| 3p视频在线观看| 嫩草影院一区二区| 日韩亚洲精品在线| 91精品麻豆| 亚洲成色最大综合在线| 国产精品久久久毛片| 99久久久国产精品美女| 男生女生差差差的视频在线观看| 99精品国产九九国产精品| 久久国产精品网站| 国产香蕉免费精品视频| 56国语精品自产拍在线观看| 国产精品视频久久久久久久| 久久久久久久久久久久久女过产乱| 香蕉视频在线免费看| 91tv在线观看| 国产日韩一区欧美| 奇米影音第四色| 美女精品一区最新中文字幕一区二区三区| 美女又爽又黄免费动漫| 国产精品视频免费一区二区三区| 日韩在线视频网址| 亚洲国产导航| 久久精品免费在线观看| 奇米777四色影视在线看| 日韩精品在线观看网站| jizzjizz日本护士视频| 亚洲成a人v欧美综合天堂| 欧美日本一区二区视频在线观看| 亚洲高清精品中出| 国产九九视频一区二区三区| 黑人精品一区二区| 国产精品揄拍100视频| 亚洲美女在线看| 精品一区中文字幕| 欧美18视频| 国产黄色网页| a'aaa级片在线观看| 国产jzjzjz丝袜老师水多| 亚洲激情 欧美| 精品欧美不卡一区二区在线观看| 久草网站在线观看| 在线免费观看色| 日日躁夜夜躁aaaabbbb| 免费黄频在线观看| 精品视频在线你懂得| 特级特黄刘亦菲aaa级| 在线观看视频一区二区三区| 这里有精品可以观看| 黄色一级片在线观看| 日韩av网站在线免费观看| 一区二区三区高清视频在线观看| 日本不卡一二三区| 久久综合九色| 欧美一级淫片免费视频魅影视频| 日韩激情在线| 中文在线手机av| 日韩视频123| 奇米一区二区三区av| 91丨九色丨蝌蚪丨老版| 国产精品日韩欧美一区二区三区| 欧美国产高潮xxxx1819| 午夜成人免费影院| 超碰人人人人人人人| 99久久国产免费| 欧美日韩电影在线观看| 成人h视频在线| 欧美在线激情网| 国产视色精品亚洲一区二区| 亚洲欧美日韩另类精品一区二区三区| 在线观看黄网| 午夜精品福利在线| 天堂网一区二区三区| 亚洲激情网站免费观看| 亚洲va久久久噜噜噜久久狠狠| 成年人三级黄色片| 一级全黄少妇性色生活片| 国产精品久久久久久久久久久免费看| 日本一区二区三级电影在线观看| 免费观看h电影在线观看| 最近日韩中文字幕中文| 日韩1区2区3区| 日韩精品欧美激情一区二区| 精品精品精品| 欧美精品成人网| 真实乱偷全部视频| 99riav国产| 午夜一级在线看亚洲| 欧美人成在线观看网站高清| 5858p先锋影音资源网| 久久亚洲综合国产精品99麻豆精品福利| 欧美男女性生活在线直播观看| 天天色综合6| 日韩欧美激情四射| 欧美精品久久久久久久久老牛影院| 亚洲国产裸拍裸体视频在线观看乱了中文| 日韩少妇一区二区| 中文字幕av久久爽av| 天堂中文在线观看视频| 91久久精品视频| 日本 国产 欧美色综合| 无码日韩精品一区二区| 久久人人爽人人爽人人片av免费| 91精品免费在线观看| 欧美一级片免费看| 韩日精品一区| 国产一区二区黄| 国产日本欧美一区二区| 欧美成人精品一区二区三区| 精品久久久久一区二区三区| 天天做天天躁天天躁| 两个人看的无遮挡免费视频| 岛国av在线免费| 热re99久久国产精品| 色综合网站在线| 精品久久久久久中文字幕一区奶水| 国产老妇另类xxxxx| 国产精品免费一区二区三区观看| 日韩欧美一级片| 欧美三级日韩在线| 97久草视频| 国产寡妇树林野战在线播放| 黑丝美女一区二区| 久久久久在线观看| 日本爱爱免费视频| 一区二区三区在线高清| 一区二区影院| 在线观看欧美黄色| 91黄色在线视频| 亚洲一区二区91| 91久久极品少妇xxxxⅹ软件| 国产女人高潮的av毛片| 国产a级免费视频| 人操人爱免费视频| 欧美一区三区二区在线观看| 欧美日韩一区二区区| av有码在线观看| 成人高潮a毛片免费观看网站| 亚洲男人的天堂在线aⅴ视频| 日韩精品欧美大片| 亚洲精品国产视频| 国产成人av免费在线观看| 老司机很黄的视频免费| 98精品国产高清在线xxxx天堂| 欧美剧情电影在线观看完整版免费励志电影| 国产精品日韩| 国产一区二区剧情av在线| 给我看免费高清在线观看| 国内精品福利| 国产精品一区二区欧美黑人喷潮水| 亚洲性av在线| 精品无人码麻豆乱码1区2区| 亚洲国产一区二区三区四区| 九九九九热精品免费视频| 欧美极度另类videos高清| 国产特级aaaaaa大片| 成人午夜在线免费| 亚洲精品午夜视频| 国产后进白嫩翘臀在线观看视频| 中文在线字幕免费观| 青青操在线观看视频| 97精品久久久中文字幕免费| 日韩av加勒比| 女~淫辱の触手3d动漫| 视频免费1区二区三区| 亚洲精品日韩在线| 婷婷综合久久中文字幕蜜桃三电影| 一级片视频播放| 日韩欧美在线不卡| 亚洲一区二区三| 国产资源在线免费观看| 翔田千里一区二区| 国产精品一区二区三区高清在线| 97精品人妻一区二区三区在线| se69色成人网wwwsex| 亚洲在线欧美| 色多多国产成人永久免费网站| 国产ts在线观看| 欧美三级电影在线观看| 亚洲国产精品91| 欧美极品影院| 国产伦精品一区二区三区88av| 99福利在线观看| 亚洲伊人久久大香线蕉av| 欧美成人黄色网| 日韩精品免费一区二区在线观看| av免费观看久久| 欧美女孩性生活视频| 久久久久久久久久久久久久久久久久久久| 国产精品国产三级国产普通话99| 国产精品theporn| 日本欧美视频在线观看| 日本亚洲一区| 狠狠做深爱婷婷久久综合一区| 久久久精品人妻一区二区三区四| 97caopron在线视频| 中文字幕久久久久久久| xxxx视频在线| 欧美大片国产精品| 国产农村老头老太视频| 国产精品国产三级在线观看| 久久99精品久久久久久青青日本| 97国产精品| 午夜免费久久看| 午夜精品久久久久久99热软件| 久久黄色av网站| 中文字幕在线看视频国产欧美在线看完整| 亚洲伦理一区| 九九久久国产| 国产一区二区在线观看免费| 粉嫩av在线播放| 免费精品一区| 久久精品最新地址| 国产又粗又长又爽又黄的视频| 成人免费网站在线观看| 国产精品久久毛片| 日韩成人一级大片| 国产女人18水真多毛片18精品| 欧美日韩国产丝袜美女| 国产日韩欧美中文在线播放| 一区二区三区精| 日精品一区二区三区| 日韩制服诱惑| 天天操精品视频| 91久久精品在线| 国产乱子夫妻xx黑人xyx真爽| 久久精品欧美日韩精品| 国产婷婷97碰碰久久人人蜜臀| 国产主播精品| 国产成人av一区二区| 欧美激情视频免费看| 亚洲人成电影院在线观看| 97人妻精品一区二区三区动漫| 久热国产在线视频| 懂色一区二区三区av片| 日本少妇激情舌吻| 国产亚洲aⅴaaaaaa毛片| 亚洲日本高清| 国产精品久久久久久中文字| 久久久精品99| 国产爆初菊在线观看免费视频网站| 色婷婷av777| 欧美精品福利在线| 4hu四虎永久在线影院成人| 五月综合激情网| 久久伊人精品天天| 日韩动漫一区| 怡红院红怡院欧美aⅴ怡春院| 国产精品海角社区在线观看| 国产主播av在线| 伊人激情综合| 日韩免费高清视频| 91久久精品日日躁夜夜躁欧美| 91农村精品一区二区在线| 久久久久久久久久婷婷| 91麻豆精品国产91久久久更新资源速度超快| 另类综合图区| 天堂网在线最新版www中文网| 日本一区免费| 99视频免费| 精品一区二区三区中文字幕老牛| 一区二区三区精密机械公司| 国产91精品一区二区麻豆亚洲| av最新在线观看| 金瓶狂野欧美性猛交xxxx| 青青青手机在线视频观看| 日本免费三片免费观看| 五月天婷婷在线观看视频| 中文字幕欧美视频| 欧美日韩国产欧| 毛片在线网址播放| 欧美午夜久久久| 国产高潮免费视频| 日本精品一区二区三区四区的功能| 国产又黄又大又粗视频| 国产又黄又大久久| 国内福利写真片视频在线| 欧美精品在欧美一区二区| 国产一区二区三区久久久久久久久| 色小说视频一区| 久久久亚洲精品视频| 五月天精品一区二区三区| 超碰人人草人人| 国产成人精品一区二区三区网站观看| 亚洲成人激情综合网| 国产精品一区二区三区四区五区| 久久99国产精品久久久久久久久| 国产福利精品av综合导导航| 中文字字幕在线中文| 成人毛片在线精品国产| 欧美日韩国产免费一区二区三区| 狼人综合视频| 伊人精品久久久久7777| 日韩成人av电影| 日操夜操天天操| 一区二区三区在线观看免费视频| 91免费版黄色| 日韩脚交footjobhdboots| 亚洲制服国产| 亚洲做受高潮无遮挡| 8848成人影院| 日韩精品中文在线观看| 国产偷激情在线| 可以看av的网站久久看| 成人免费网站在线看| 欧美jizzhd精品欧美巨大免费| 久久久久亚洲av无码专区首jn| 日本一区二区三区精品| 国产美女精品视频免费播放软件| 香蕉视频成人在线观看| 亚洲精品在线播放视频| 亚洲精品国偷拍自产在线观看蜜桃| 国产69精品久久久久按摩| 亚洲欧美激情一区二区| 人妖精品videosex性欧美| 国产高潮在线观看| 日本一区免费在线观看| 欧美体内she精高潮| 久久亚洲精品石原莉奈| 国产欧美一区二区精品久久久| 精品国产一级毛片| 日韩欧美一区二区三区免费看| 日本一区免费| 亚洲专区视频| 国产激情美女久久久久久吹潮| 欧美另类高清videos的特点| 午夜xxxxx|