久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

js断点和调试学习总结3

發(fā)布時(shí)間:2025/4/14 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js断点和调试学习总结3 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

使用Chrome調(diào)試JavaScript的斷點(diǎn)設(shè)置和調(diào)試技巧


你是怎么調(diào)試 JavaScript 程序的?最原始的方法是用 alert() 在頁(yè)面上打印內(nèi)容,稍微改進(jìn)一點(diǎn)的方
法是用 console.log() 在 JavaScript 控制臺(tái)上輸出內(nèi)容。嗯~,用這兩種土辦法確實(shí)解決了很多小型?
JavaScript 腳本的調(diào)試問(wèn)題。不過(guò)放著 Chrome 中功能越發(fā)強(qiáng)大的開(kāi)發(fā)者工具不用實(shí)在太可惜了。本文
主要介紹其中的 JavaScript斷點(diǎn)設(shè)置和調(diào)試功能,也就是其中的 Sources Panel(以前叫 Scripts)。
如果你精通 Eclipse 中的各種 Java 調(diào)試技巧,那么這里的概念都是類(lèi)似。寫(xiě)作本文時(shí)使用的 Chrome?
版本為 25.0.1364.172。


基本環(huán)境

SourcesPanel 的左邊是內(nèi)容源,包括頁(yè)面中的各種資源。其中,又分 Sources 和 Content scripts。
Sources 就是頁(yè)面本身包含的各種資源,它是按照頁(yè)面中出現(xiàn)的域來(lái)組織的,這是我們要關(guān)注的。異步
加載的 js 文件,在加載后也會(huì)出現(xiàn)在這里的。Content scripts 是 Chrome 的一種擴(kuò)展程序,它是按
照擴(kuò)展的ID來(lái)組織的,這類(lèi)擴(kuò)展實(shí)際也是嵌入在頁(yè)面中的資源,它們也可以讀寫(xiě)DOM。編寫(xiě)、調(diào)試這類(lèi)擴(kuò)
展的開(kāi)發(fā)者才要關(guān)心它們,如果你的瀏覽器沒(méi)安裝任何擴(kuò)展,那么Content scripts 就看不到任何東西

Sources Panel 的中間主區(qū)域用于展示左邊資源文件的內(nèi)容。
Sources Panel 的右邊是調(diào)試功能區(qū),最上面的一排按鈕分別是暫停/繼續(xù)、單步執(zhí)行、單步跳入、單步
跳出、禁用/啟用所有斷點(diǎn)。下面是各種具體的功能區(qū)。稍后介紹。
注意,左右兩邊的區(qū)域默認(rèn)可能收縮在兩側(cè)沒(méi)有顯示出來(lái),點(diǎn)擊兩側(cè)的伸縮按鈕展示出來(lái)。左邊區(qū)域展
示出來(lái)時(shí)默認(rèn)是自動(dòng)收縮狀態(tài),點(diǎn)擊旁邊的 pin 按鈕就不會(huì)縮回去了。
最下面還有一些功能按鈕很有用。


在源代碼上設(shè)置斷點(diǎn)

通過(guò)左邊的內(nèi)容源,打開(kāi)對(duì)應(yīng)的 JavaScript 文件,鼠標(biāo)點(diǎn)擊文件的行號(hào)就可以設(shè)置和刪除斷點(diǎn)。添加
的每個(gè)斷點(diǎn)都會(huì)出現(xiàn)在右側(cè)調(diào)試區(qū)的 Breakpoints 列表中,點(diǎn)擊列表中斷點(diǎn)就會(huì)定位到內(nèi)容區(qū)的斷點(diǎn)上
。如果你有多個(gè)文件、多個(gè)斷點(diǎn)的話,利用Breakpoints 列表中的斷點(diǎn)快速定位非常方便。
對(duì)于每個(gè)已添加的斷點(diǎn)都有兩種狀態(tài):激活和禁用。剛添加的斷點(diǎn)都是激活狀態(tài),禁用狀態(tài)就是保留斷
點(diǎn)但臨時(shí)取消該斷點(diǎn)功能。在Breakpoints 列表中每個(gè)斷點(diǎn)前面都有一個(gè)復(fù)選框,取消選中就將禁用該
斷點(diǎn)。斷點(diǎn)位置的右鍵菜單中也可以禁用斷點(diǎn)。也可以在右側(cè)功能區(qū)上面按鈕臨時(shí)禁用所有已添加的斷
點(diǎn),再點(diǎn)一下恢復(fù)原狀態(tài)。


條件斷點(diǎn):在斷點(diǎn)位置的右鍵菜單中選擇“Edit Breakpoint...”可以設(shè)置觸發(fā)斷點(diǎn)的條件,就是寫(xiě)一

個(gè)表達(dá)式,表達(dá)式為 true 時(shí)才觸發(fā)斷點(diǎn)。查看斷點(diǎn)的環(huán)境調(diào)用棧(Call Stack):在斷點(diǎn)停下來(lái)時(shí),
右側(cè)調(diào)試區(qū)的 Call Stack 會(huì)顯示當(dāng)前斷點(diǎn)所處的方法調(diào)用棧,比如有一個(gè)函數(shù) g() 其中又調(diào)用了函數(shù)?
f() ,而我在 f() 中設(shè)置了一個(gè)斷點(diǎn),那么我在 console 中執(zhí)行函數(shù) g() 的時(shí)候會(huì)觸發(fā)斷點(diǎn),其調(diào)用
棧顯示如下:
最上面是 f(),然后是 g()。調(diào)用棧中的每一層叫做一個(gè) frame,點(diǎn)擊每個(gè) frame 可以跳到該 frame?
的調(diào)用點(diǎn)上。
此外,還可以在 frame 上用右鍵菜單重新開(kāi)始執(zhí)行當(dāng)前 frame,也就是從該 frame 的開(kāi)始處執(zhí)行。比
如在函數(shù) f() 的 frame 上 Restart Frame, 斷點(diǎn)就會(huì)跳到 f() 的開(kāi)頭重新執(zhí)行,context 中的變量
值也會(huì)還原。這樣結(jié)合變量修改和編輯代碼等功能,就可以在當(dāng)前 frame 中反復(fù)進(jìn)行調(diào)試,而不用刷新
頁(yè)面重新觸發(fā)斷點(diǎn)了。查看變量

Call Stack 列表的下方是 Scope Variables 列表,在這里可以查看此時(shí)局部變量和全局變量的值。執(zhí)

行選擇的代碼

在斷點(diǎn)調(diào)試時(shí),可以用鼠標(biāo)選擇想要查看的變量或表達(dá)式,然后右鍵菜單執(zhí)行“Evaluate in Console”

,就可以看到該表達(dá)式的當(dāng)前的值了。中斷下次要執(zhí)行的 JavaScript 語(yǔ)句右側(cè)調(diào)試區(qū)的上面的“中斷/

繼續(xù)”按鈕還有一個(gè)功能,在沒(méi)有觸發(fā)斷點(diǎn)時(shí),點(diǎn)一下這個(gè)按鈕就會(huì)進(jìn)入“準(zhǔn)備”中斷的狀態(tài),頁(yè)面下

一次執(zhí)行 JavaScript 語(yǔ)句時(shí)會(huì)自動(dòng)中斷,比如觸發(fā)了一個(gè)點(diǎn)擊動(dòng)作時(shí)會(huì)執(zhí)行的代碼。臨時(shí)修改?

JavaScript 代碼通常我們?cè)谡{(diào)試代碼時(shí)習(xí)慣:修改代碼→刷新頁(yè)面→重新檢查,這么一個(gè)循環(huán)。但其實(shí)?

Chrome 中可以臨時(shí)修改 JS 文件中的內(nèi)容,保存(Ctrl+S)就可以立即生效,結(jié)合 Console 等功能就

可以立即重新調(diào)試了。但注意這個(gè)修改是臨時(shí)的,刷新頁(yè)面修改就沒(méi)了。
異常時(shí)斷點(diǎn)
在界面下方能看到按鈕,它是設(shè)置程序運(yùn)行時(shí)遇到異常時(shí)是否中斷的開(kāi)關(guān)。點(diǎn)擊該按鈕會(huì)在3種狀態(tài)間切
換:
默認(rèn)遇到異常不中斷
遇到所有異常都會(huì)中斷,包括已捕獲的情況
僅在出現(xiàn)未捕獲的異常時(shí)才中斷
主要解釋一下?tīng)顟B(tài)2和狀態(tài)3的區(qū)別
try{ throw 'a exception'; }catch(e){ console.log(e); }
上面 try 里面的代碼會(huì)遇到異常,但是后面的 catch 代碼能夠捕獲該異常。如果是所有異常都中斷,

那么代碼執(zhí)行到會(huì)產(chǎn)生異常的 throw 語(yǔ)句時(shí)就會(huì)自動(dòng)中斷;而如果是僅遇到未捕獲異常才中斷,那么這

里就不會(huì)中斷。一般我們會(huì)更關(guān)心遇到未捕獲異常的情況。
在 DOM 元素上設(shè)置斷點(diǎn)
有時(shí)候我們需要監(jiān)聽(tīng)某個(gè) DOM 被修改情況,而不關(guān)心是哪行代碼做的修改(也可能有多處都會(huì)對(duì)其做修

改)。那么我們可以直接在 DOM 上設(shè)置斷點(diǎn)。


如圖所見(jiàn),在元素審查的 Elements Panel 中在某個(gè)元素上右鍵菜單里可以設(shè)置三種不同情況的斷點(diǎn):
子節(jié)點(diǎn)修改自身屬性修改自身節(jié)點(diǎn)被刪除選中之后,Sources Panel 中右側(cè)的 DOM Breakpoints 列表中
就會(huì)出現(xiàn)該 DOM 斷點(diǎn)。一旦執(zhí)行到要對(duì)該 DOM 做相應(yīng)修改時(shí),代碼就會(huì)在那里停下來(lái),如下圖所示。
XHR 斷點(diǎn)
右側(cè)調(diào)試區(qū)有一個(gè) XHR Breakpoints,點(diǎn)擊+ 并輸入 URL 包含的字符串即可監(jiān)聽(tīng)該 URL 的 Ajax 請(qǐng)求
,輸入內(nèi)容就相當(dāng)于 URL 的過(guò)濾器。如果什么都不填,那么就監(jiān)聽(tīng)所有 XHR 請(qǐng)求。一旦 XHR 調(diào)用觸發(fā)
時(shí)就會(huì)在 request.send() 的地方中斷。
按事件類(lèi)型觸發(fā)斷點(diǎn)
右側(cè)調(diào)試區(qū)的Event Listener 列表,這里列出了各種可能的事件類(lèi)型。勾選對(duì)應(yīng)的事件類(lèi)型,當(dāng)觸發(fā)了

該類(lèi)型的事件的 JavaScript 代碼時(shí)就會(huì)自動(dòng)中斷。


調(diào)試快捷鍵
所有開(kāi)發(fā)工具中的快捷鍵都可以在界面右下角的設(shè)置中查到。斷點(diǎn)調(diào)試時(shí)一般用的是 F8、F10、F11或?
Shitf+F11,但在 Mac OS 上 F10 等功能鍵可能與系統(tǒng)默認(rèn)的快捷鍵沖突。沒(méi)關(guān)系,它們分別可以用?
Cmd+/ 、Cmd+'、Cmd+; 、Shift+Cmd+; 代替。//@ sourceURL 給 eval 出來(lái)的代碼命名有時(shí)候一些非常
動(dòng)態(tài)的代碼是以字符串的形式通過(guò) eval() 函數(shù)在當(dāng)前 Javascript context 中創(chuàng)建出來(lái),而不是作為
一個(gè)獨(dú)立的 js 文件加載的。這樣你在左邊的內(nèi)容區(qū)就找不到這個(gè)文件,因此很難調(diào)試。其實(shí)我們只要
在 eval 創(chuàng)建的代碼末尾添加一行 “//@ sourceURL=name“就可以給這段代碼命名(瀏覽器會(huì)特殊對(duì)待
這種特殊形式的注釋),這樣它就會(huì)出現(xiàn)在左側(cè)的內(nèi)容區(qū)了,就好像你加載了一個(gè)指定名字的 js 文件

一樣,可以設(shè)置斷點(diǎn)和調(diào)試了。下圖中,我們通過(guò) eval 執(zhí)行了一段代碼,并利用sourceURL 將它命名

為dynamicScript.js ,執(zhí)行后左側(cè)內(nèi)容區(qū)就出現(xiàn)了這個(gè)“文件”,而它的內(nèi)容就是 eval 的中的內(nèi)容。

還可以看看這個(gè)給動(dòng)態(tài)編譯出來(lái)的CoffeeScript 代碼命名的示例:
var coffee = CoffeeScript.compile(code.value)+ "//@ sourceURL=" + (evalName.value ||?


"Coffeeeeeeee!");
eval(coffee);
實(shí)際上,//@ sourceURL 不僅僅可以用在 eval 的代碼中,任何 js 文件、甚至是 Javascript Console?


輸入的代碼都可以用,效果一樣!格式化代碼(Pretty Print)按鈕用于把雜亂的代碼重新格式化為漂


亮的代碼,比如一些已被壓縮的 js 文件基本沒(méi)法看、更沒(méi)法調(diào)試。點(diǎn)一下格式化,再點(diǎn)一下就取消格


式化。
========

JavaScript調(diào)試技巧之console.log()詳解



對(duì)于JavaScript程序的調(diào)試,相比于alert(),使用console.log()是一種更好的方式,原因在于:

alert()函數(shù)會(huì)阻斷JavaScript程序的執(zhí)行,從而造成副作用;而console.log()僅在控制臺(tái)中打印相關(guān)

信息,因此不會(huì)造成類(lèi)似的顧慮

一、什么是console.log()?
除了一些很老版本的瀏覽器,現(xiàn)今大多數(shù)瀏覽器都自帶調(diào)試功能;即使沒(méi)有調(diào)試功能,也可以通過(guò)安裝

插件來(lái)進(jìn)行補(bǔ)充。比如,老版本的Firefox沒(méi)有自帶調(diào)試工具,在這種情況下可以通過(guò)安裝Firebug插件

來(lái)添加調(diào)試功能。在具備調(diào)試功能的瀏覽器上,window對(duì)象中會(huì)注冊(cè)一個(gè)名為console的成員變量,指代

調(diào)試工具中的控制臺(tái)。通過(guò)調(diào)用該console對(duì)象的log()函數(shù),可以在控制臺(tái)中打印信息。比如,以下代

碼將在控制臺(tái)中打印”Sample log”:
復(fù)制代碼 代碼如下:
window.console.log("Sample log");

上述代碼可以忽略window對(duì)象而直接簡(jiǎn)寫(xiě)為:
復(fù)制代碼 代碼如下:
console.log("Sample log");

console.log()可以接受任何字符串、數(shù)字和JavaScript對(duì)象。與alert()函數(shù)類(lèi)似,console.log()也可

以接受換行符\n以及制表符\t。console.log()語(yǔ)句所打印的調(diào)試信息可以在瀏覽器的調(diào)試控制臺(tái)中看到

。不同的瀏覽器中console.log()行為可能會(huì)有所不同, 本文主要探討Firebug中console.log()的使用?


二、兼容沒(méi)有調(diào)試控制臺(tái)的瀏覽器
對(duì)于缺少調(diào)試控制臺(tái)的老版本瀏覽器,window中的console對(duì)象并不存在,因此直接使用console.log()

語(yǔ)句可能會(huì)在瀏覽器內(nèi)部造成錯(cuò)誤(空指針錯(cuò)誤),并最終導(dǎo)致某些老版本瀏覽器的崩潰。為了解決這一

問(wèn)題,可以人為定義console對(duì)象,并聲明該console對(duì)象的log函數(shù)為空函數(shù);這樣,當(dāng)console.log()

語(yǔ)句執(zhí)行時(shí),這些老版本的瀏覽器將不會(huì)做任何事情:
代碼如下:
if(!window.console){window.console = {log : function(){}}; }

不過(guò),在大多數(shù)情況下,沒(méi)有必要去做這種兼容性工作 — console.log()等調(diào)試代碼應(yīng)當(dāng)從最終的產(chǎn)品

代碼中刪除掉。
三、使用參數(shù)
與alert()函數(shù)類(lèi)似,console.log()也可以接受變量并將其與別的字符串進(jìn)行拼接:
復(fù)制代碼 代碼如下:
//Use variable
var name = "Bob";
console.log("The name is: " + name);

與alert()函數(shù)不同的是,console.log()還可以接受變量作為參數(shù)傳遞到字符串中,其具體語(yǔ)法與C語(yǔ)言

中的printf語(yǔ)法一致:
復(fù)制代碼 代碼如下:
//Use parameter
var people = "Alex";
var years = 42;
console.log("%s is %d years old.", people, years);

上述代碼的執(zhí)行結(jié)果為:”Alex is 42 years old.”
四、使用其它日志級(jí)別
除了console.log(),Firebug還支持多種不同的日志級(jí)別:debug、info、warn、error。以下代碼將在

控制臺(tái)中打印這些不同日志級(jí)別的信息:
代碼如下:
//Use different logging level console.log("Log level"); console.debug("Debug level"); console.info("Info level"); console.warn("Warn level"); console.error("Error level");

從Firebug控制臺(tái)中可以看到,不同日志級(jí)別的打印信息,其顏色和圖標(biāo)是不一樣的;同時(shí),可以在控制

臺(tái)中選擇不同的日志級(jí)別來(lái)對(duì)這些信息進(jìn)行過(guò)濾:?
========

JS調(diào)試必備的5個(gè)debug技巧


我一直使用printf調(diào)試程序,一般來(lái)說(shuō)都是比較順利,但有時(shí)候,你會(huì)發(fā)現(xiàn)需要更好的方法。下面幾個(gè)


JavaScript技巧相信你一定會(huì)覺(jué)得十分有用

1. debugger;
我以前也說(shuō)過(guò),你可以在JavaScript代碼中加入一句debugger;來(lái)手工造成一個(gè)斷點(diǎn)效果。
需要帶有條件的斷點(diǎn)嗎?你只需要用if語(yǔ)句包圍它:
復(fù)制代碼 代碼如下:
if (somethingHappens) {
? debugger;
}


但要記住在程序發(fā)布前刪掉它們。
2. 設(shè)置在DOM node發(fā)生變化時(shí)觸發(fā)斷點(diǎn)
有時(shí)候你會(huì)發(fā)現(xiàn)DOM不受你的控制,自己會(huì)發(fā)生一些奇怪的變化,讓你很難找出問(wèn)題的根源。
谷歌瀏覽器的開(kāi)發(fā)工具里有一個(gè)超級(jí)好用的功能,專(zhuān)門(mén)可以對(duì)付這種情況,叫做“Break on…”,你在


DOM節(jié)點(diǎn)上右鍵,就能看到這個(gè)菜單項(xiàng)。
斷點(diǎn)的觸發(fā)條件可以設(shè)置成這個(gè)節(jié)點(diǎn)被刪除、節(jié)點(diǎn)的屬性有任何變化,或它的某個(gè)子節(jié)點(diǎn)有變化發(fā)生。


3. Ajax 斷點(diǎn)
XHR斷點(diǎn),或Ajax斷點(diǎn),就像它們的名字一樣,可以讓我們?cè)O(shè)置一個(gè)斷點(diǎn),在特點(diǎn)的Ajax調(diào)用發(fā)生時(shí)觸發(fā)

它們。
當(dāng)你在調(diào)試Web應(yīng)用的網(wǎng)絡(luò)傳輸時(shí),這一招非常的有效。



4. 移動(dòng)設(shè)備模擬環(huán)境
谷歌瀏覽器里有一些非常有趣的模擬移動(dòng)設(shè)備的工具,幫助我們調(diào)試程序在移動(dòng)設(shè)備里的運(yùn)行情況。
找到它的方法是:按F12,調(diào)出開(kāi)發(fā)者工具,然后按ESC鍵(當(dāng)前tab不能是Console),你就會(huì)看到第二層


調(diào)試窗口出現(xiàn),里面的Emulation標(biāo)簽頁(yè)里有各種模擬設(shè)備可選。
當(dāng)然,這不會(huì)就變成了真正的iPhone,只是模擬了iPhone的尺寸,觸摸事件和瀏覽器User Agent值。



5. 使用Audits改進(jìn)你的網(wǎng)站
YSlow是一個(gè)非常棒的工具。谷歌瀏覽器的開(kāi)發(fā)者工具里也有一個(gè)非常類(lèi)似的工具,叫Audits。
它可快速的審計(jì)你的網(wǎng)站,給你提出非常實(shí)際有效的優(yōu)化你的網(wǎng)站的建議和方法。


還有其它的嗎?
沒(méi)有這些工具,我不知道將如何開(kāi)發(fā)。我還會(huì)寫(xiě)更多的關(guān)于這方面的技巧——一旦我有所發(fā)現(xiàn),請(qǐng)關(guān)注

我的最新文章。
========

必備的JS調(diào)試技巧匯總



試想一下:出現(xiàn)了某個(gè)bug,有人用幾分鐘就搞定了,有人用了半天或者一天都找不到原因所在。你愿意


當(dāng)前者還是后者呢?想當(dāng)前者的就請(qǐng)好好看完本篇文章吧。文中涉及較多Gif演示動(dòng)畫(huà)請(qǐng)注意。


前言:任何一個(gè)編程者都少不了要去調(diào)試代碼,不管你是高手還是菜鳥(niǎo),調(diào)試程序都是一項(xiàng)必不可少的


工作。一般來(lái)說(shuō)調(diào)試程序是在編寫(xiě)代碼之后或測(cè)試期修改Bug 時(shí)進(jìn)行的,往往在調(diào)試代碼期間更加能夠


體現(xiàn)出編程者的水平高低以及分析問(wèn)題的準(zhǔn)確度。不少初學(xué)者在尋找錯(cuò)誤原因時(shí),總是不得要領(lǐng),花費(fèi)


了大量時(shí)間卻無(wú)法解決一些最終證明是相當(dāng)簡(jiǎn)單的Bug。掌握各種調(diào)試技巧,必定能在工作中起到事半功


倍的效果。譬如,快速定位問(wèn)題、降低故障概率、幫助分析邏輯錯(cuò)誤等等。而在互聯(lián)網(wǎng)前端開(kāi)發(fā)越來(lái)越


重要的今天,如何在前端開(kāi)發(fā)中降低開(kāi)發(fā)成本,提升工作效率,掌握前端開(kāi)發(fā)調(diào)試技巧尤為重要。
本文將一一講解各種前端JS調(diào)試技巧,也許你已經(jīng)熟練掌握,那讓我們一起來(lái)溫習(xí),也許有你沒(méi)見(jiàn)過(guò)的


方法,不妨一起來(lái)學(xué)習(xí),也許你尚不知如何調(diào)試,趕緊趁此機(jī)會(huì)填補(bǔ)空白。
1、骨灰級(jí)調(diào)試大師Alert
那還是互聯(lián)網(wǎng)剛剛起步的時(shí)代,網(wǎng)頁(yè)前端還主要以?xún)?nèi)容展示為主,瀏覽器腳本還只能為頁(yè)面提供非常簡(jiǎn)


單的輔助功能的時(shí)候。那個(gè)時(shí)候,網(wǎng)頁(yè)主要運(yùn)行在以IE6為主的瀏覽器中,JS的調(diào)試功能還非常弱,只能


通過(guò)內(nèi)置于Window對(duì)象中的alert方法來(lái)調(diào)試,那時(shí)候看起來(lái)應(yīng)該是這個(gè)樣子:


需要說(shuō)明一點(diǎn),這里看到的效果,并非當(dāng)年的IE瀏覽器中看到的效果,而是在高版本IE中的效果。此外


,當(dāng)年貌似還沒(méi)有這么高級(jí)的控制臺(tái),而alert的使用也是在真實(shí)的頁(yè)面JS代碼中。雖然,alert的調(diào)試


方式很原始,但當(dāng)時(shí)確實(shí)有它不可磨滅的價(jià)值,甚至到今天,已然有其用武之地。
2、新一代調(diào)試王者Console
隨著JS在Web前端中能做的事情越來(lái)越多,責(zé)任越來(lái)越大,而地位也越來(lái)越重要。傳統(tǒng)的alert調(diào)試方式


已經(jīng)漸漸不能滿(mǎn)足前端開(kāi)發(fā)的種種場(chǎng)景。而且alert調(diào)試方式彈出的調(diào)試信息,那個(gè)窗口著實(shí)不太美觀,


而且會(huì)遮擋部分頁(yè)面內(nèi)容,著實(shí)有些不太友好。
另一方面,alert的調(diào)試信息,必須在程序邏輯中添加類(lèi)似"alert(xxxxx)"這樣的語(yǔ)句,才能正常工作,


并且alert會(huì)阻礙頁(yè)面的繼續(xù)渲染。這就意味著開(kāi)發(fā)人員調(diào)試完成后,必須手動(dòng)清除這些調(diào)試代碼,實(shí)在


有些麻煩。
所以,新一代的瀏覽器Firefox、Chrome,包括IE,都相繼推出了JS調(diào)試控制臺(tái),支持使用類(lèi)


似"console.log(xxxx)"的形式,在控制臺(tái)打印調(diào)試信息,而不直接影響頁(yè)面顯示。以IE為例,它看起來(lái)


像這樣:


好吧,再見(jiàn)丑陋的alert彈出框。而以Chrome瀏覽器為首的后起之秀,為Console擴(kuò)展了更豐富的功能:


你以為這樣就滿(mǎn)足了?Chrome開(kāi)發(fā)團(tuán)隊(duì)的想象力實(shí)在不得不讓人佩服:

好了,稍微多說(shuō)了一點(diǎn)點(diǎn)題外話。總之,控制臺(tái)以及瀏覽器內(nèi)置Console對(duì)象的出現(xiàn),給前端開(kāi)發(fā)調(diào)試帶


來(lái)了極大的便利。
有人會(huì)問(wèn),這樣的調(diào)試代碼不一樣需要在調(diào)試完成后進(jìn)行清理嗎?
關(guān)于這個(gè)問(wèn)題,如果在使用console對(duì)象之前先進(jìn)性存在性驗(yàn)證,其實(shí)不刪除也不會(huì)對(duì)業(yè)務(wù)邏輯造成破壞


。當(dāng)然,為了代碼整潔,在調(diào)試完成后,還是應(yīng)盡可能刪除這些與業(yè)務(wù)邏輯無(wú)關(guān)的調(diào)試代碼。
3、JS斷點(diǎn)調(diào)試
斷點(diǎn),調(diào)試器的功能之一,可以讓程序中斷在需要的地方,從而方便其分析。也可以在一次調(diào)試中設(shè)置


斷點(diǎn),下一次只需讓程序自動(dòng)運(yùn)行到設(shè)置斷點(diǎn)位置,便可在上次設(shè)置斷點(diǎn)的位置中斷下來(lái),極大的方便

了操作,同時(shí)節(jié)省了時(shí)間。——百度百科
JS斷點(diǎn)調(diào)試,即是在瀏覽器開(kāi)發(fā)者工具中為JS代碼添加斷點(diǎn),讓JS執(zhí)行到某一特定位置停住,方便開(kāi)發(fā)


者對(duì)該處代碼段的分析與邏輯處理。為了能夠觀察到斷點(diǎn)調(diào)試的效果,我們預(yù)先隨意準(zhǔn)備一段JS代碼:


代碼很簡(jiǎn)單,就是定義一個(gè)函數(shù),傳入兩個(gè)數(shù),分別加上一個(gè)亂七八糟的隨機(jī)整數(shù)后,再返回兩個(gè)數(shù)的


總和。以Chrome開(kāi)發(fā)者工具為例,我們來(lái)看一下JS斷點(diǎn)調(diào)試的基本方法。
3.1、Sources斷點(diǎn)
首先,測(cè)試代碼中我們通過(guò)上圖console的輸出結(jié)果可以看出代碼應(yīng)該是正常運(yùn)行了,但是為什么是應(yīng)該


呢?因?yàn)楹瘮?shù)中加了一個(gè)隨機(jī)數(shù),而最終結(jié)果是否真的是正確的呢?這是毫無(wú)意義的猜想,但是假設(shè)我


現(xiàn)在就是要驗(yàn)證一下:函數(shù)傳入的兩個(gè)數(shù)、被加的隨機(jī)數(shù),以及最終的總和。那么該怎么操作呢?
方法一,前面講過(guò)最普通的,無(wú)論使用alert還是console,我們可以這么來(lái)驗(yàn)證:


從上圖發(fā)現(xiàn),我們?cè)诖a中新增了三行console代碼,用以打印我們關(guān)心的數(shù)據(jù)變量,而最終我們從控制


臺(tái)(Console面板)中的輸出結(jié)果,可以很清楚的驗(yàn)證整個(gè)計(jì)算過(guò)程是否正常,進(jìn)而達(dá)到我們題設(shè)的驗(yàn)證


要求。
方法二,方法一的驗(yàn)證過(guò)程存在很明顯的弊端就是,添加了很多冗余代碼,接下來(lái)我們看一下使用斷點(diǎn)


進(jìn)行驗(yàn)證,是否更加方便,先看一個(gè)如何加斷點(diǎn),以及斷點(diǎn)后是什么效果:


如圖,給一段代碼添加斷點(diǎn)的流程是"F12(Ctrl + Shift + I)打開(kāi)開(kāi)發(fā)工具"——"點(diǎn)擊Sources菜單"


——"左側(cè)樹(shù)中找到相應(yīng)文件"——"點(diǎn)擊行號(hào)列"即完成在當(dāng)前行添加/刪除斷點(diǎn)操作。當(dāng)斷點(diǎn)添加完畢后


,刷新頁(yè)面JS執(zhí)行到斷點(diǎn)位置停住,在Sources界面會(huì)看到當(dāng)前作用域中所有變量和值,只需對(duì)每個(gè)值進(jìn)


行驗(yàn)證即可完成我們題設(shè)驗(yàn)證要求。
那問(wèn)題來(lái)了,仔細(xì)的朋友會(huì)發(fā)現(xiàn)當(dāng)我的代碼執(zhí)行到斷點(diǎn)的時(shí)候,顯示的變量a和b的值是已經(jīng)進(jìn)行過(guò)加法


運(yùn)算后的,我們看不到調(diào)用sum函數(shù)時(shí)初始傳入的10和20。那么該怎么辦呢?這就要回過(guò)頭來(lái)先學(xué)習(xí)一下


斷點(diǎn)調(diào)試的一些基礎(chǔ)知識(shí)了。我們打開(kāi)Sources面板后其實(shí)會(huì)在界面中看到如下內(nèi)容,我們跟著鼠標(biāo)軌跡


逐一看看都是什么意思:


從左到右,各個(gè)圖標(biāo)表示的功能分別為:
Pause/Resume script execution:暫停/恢復(fù)腳本執(zhí)行(程序執(zhí)行到下一斷點(diǎn)停止)。
Step over next function call:執(zhí)行到下一步的函數(shù)調(diào)用(跳到下一行)。
Step into next function call:進(jìn)入當(dāng)前函數(shù)。
Step out of current function:跳出當(dāng)前執(zhí)行函數(shù)。
Deactive/Active all breakpoints:關(guān)閉/開(kāi)啟所有斷點(diǎn)(不會(huì)取消)。
Pause on exceptions:異常情況自動(dòng)斷點(diǎn)設(shè)置。
到此,斷點(diǎn)調(diào)試的功能鍵介紹得差不多了,接下來(lái)我們就可以一行一行去看我們的程序代碼,查看每一


行執(zhí)行完畢之后,我們各個(gè)變量的變化情況了,如下圖所示:


如上,我們可以看到a、b變量從最初值,到中間加上隨機(jī)值,再到最后計(jì)算總和并輸出最終結(jié)果的整個(gè)


過(guò)程,完成題設(shè)驗(yàn)證要求不在話下。
其余幾個(gè)功能鍵,我們稍微改動(dòng)一下我們的測(cè)試代碼,用一張gif圖來(lái)演示他們的使用方法:


這里需要注意一點(diǎn),直接在代碼區(qū)打印變量值的功能是在較新版本的Chrome瀏覽器中才新增的功能,如


果你還在使用較老版本的Chrome瀏覽器,可能無(wú)法直接在斷點(diǎn)的情況下查看變量信息,此時(shí)你可以將鼠


標(biāo)移動(dòng)到變量名上短暫停頓則會(huì)出現(xiàn)變量值。也可以用鼠標(biāo)選中變量名稱(chēng),然后右鍵"Add to watch"在


Watch面板查看,此方法同樣適用于表達(dá)式。此外,你還可以在斷點(diǎn)情況下,切換到Console面板,直接


在控制臺(tái)輸入變量名稱(chēng),回車(chē)查看變量信息。該部分比較簡(jiǎn)單,考慮篇幅問(wèn)題,不在做圖演示。
3.2、Debugger斷點(diǎn)
所謂的Debugger斷點(diǎn),其實(shí)是我自己給它命名的,專(zhuān)業(yè)術(shù)語(yǔ)我也不知道怎么說(shuō)。具體的說(shuō)就是通過(guò)在代


碼中添加"debugger;"語(yǔ)句,當(dāng)代碼執(zhí)行到該語(yǔ)句的時(shí)候就會(huì)自動(dòng)斷點(diǎn)。接下去的操作就跟在Sources面


板添加斷點(diǎn)調(diào)試幾乎一模一樣,唯一的區(qū)別在于調(diào)試完后需要?jiǎng)h除該語(yǔ)句。
既然除了設(shè)置斷點(diǎn)的方式不一樣,功能和Sources面板添加斷點(diǎn)效果一樣,那么為什么還會(huì)存在這種方式


呢?我想原因應(yīng)該是這樣的:我們?cè)陂_(kāi)發(fā)中偶爾會(huì)遇到異步加載html片段(包含內(nèi)嵌JS代碼)的情況,


而這部分JS代碼在Sources樹(shù)種無(wú)法找到,因此無(wú)法直接在開(kāi)發(fā)工具中直接添加斷點(diǎn),那么如果想給異步


加載的腳本添加斷點(diǎn),此時(shí)"debugger;"就發(fā)揮作用了。我們直接通過(guò)gif圖看看他的效果:


4、DOM斷點(diǎn)調(diào)試
DOM斷點(diǎn),顧名思義就是在DOM元素上添加斷點(diǎn),進(jìn)而達(dá)到調(diào)試的目的。而在實(shí)際使用中斷點(diǎn)的效果最終


還是落地到JS邏輯之內(nèi)。我們依次來(lái)看一下每一種DOM斷點(diǎn)的具體效果。
4.1、當(dāng)節(jié)點(diǎn)內(nèi)部子節(jié)點(diǎn)變化時(shí)斷點(diǎn)(Break on subtree modifications)
在前端開(kāi)發(fā)越來(lái)越復(fù)雜的今天,前端JS代碼越來(lái)越多,邏輯越來(lái)越復(fù)雜,一個(gè)看似簡(jiǎn)單的Web頁(yè)面,通常


伴隨著大段大段的JS代碼,涉及諸多DOM節(jié)點(diǎn)增、刪、改的操作。難免遇到直接通過(guò)JS代碼很難定位代碼


段的情況,而我們卻可以通過(guò)開(kāi)發(fā)者工具的Elements面板,快速定位到相關(guān)DOM節(jié)點(diǎn),這時(shí)候通過(guò)DOM斷


點(diǎn)定位腳本就顯得尤其重要了。具體我們還是通過(guò)gif演示來(lái)看一下吧:


上圖演示了對(duì)ul子節(jié)點(diǎn)(li)的增加、刪除以及交換順序操作觸發(fā)斷點(diǎn)的效果。但需要注意的是,對(duì)子


節(jié)點(diǎn)進(jìn)行屬性修改和內(nèi)容修改并不會(huì)觸發(fā)斷點(diǎn)。
4.2、當(dāng)節(jié)點(diǎn)屬性發(fā)生變化時(shí)斷點(diǎn)(Break on attributes modifications)
另一方面,由于前端處理的業(yè)務(wù)邏輯越來(lái)越復(fù)雜,對(duì)一些數(shù)據(jù)的存儲(chǔ)依賴(lài)越來(lái)越強(qiáng)烈,而將臨時(shí)數(shù)據(jù)存


儲(chǔ)于DOM節(jié)點(diǎn)的(自定義)屬性中,是很多情況下開(kāi)發(fā)者優(yōu)先選擇的方式。特別是在HTML5標(biāo)準(zhǔn)增強(qiáng)自定


義屬性支持(例:dataset、data-*之類(lèi))之后,屬性設(shè)置應(yīng)用越來(lái)越多,因此Chrome開(kāi)發(fā)者工具也提供


了屬性變化斷點(diǎn)支持,其效果大致如下:


此方式同樣需要注意,對(duì)子節(jié)點(diǎn)的屬性進(jìn)行任何操作也不會(huì)觸發(fā)節(jié)點(diǎn)本身的斷點(diǎn)。
4.3、當(dāng)節(jié)點(diǎn)被移除時(shí)斷點(diǎn)(Break on node removal)
這個(gè)DOM斷點(diǎn)設(shè)置很簡(jiǎn)單,觸發(fā)方式很明確——當(dāng)節(jié)點(diǎn)被刪除時(shí)。所以通常情況應(yīng)該是在執(zhí)


行"parentNode.removeChild(childNode)"語(yǔ)句的時(shí)候使用此方式。此方式使用不多。
前面介紹到的基本上是我們?cè)谌粘i_(kāi)發(fā)中經(jīng)常用到的調(diào)試手段,運(yùn)用得當(dāng)它們也幾乎能應(yīng)對(duì)我們?nèi)粘i_(kāi)


發(fā)中的幾乎所有問(wèn)題。但是,開(kāi)發(fā)者工具還考慮到了更多的情況,提供更多的斷點(diǎn)方式,如圖:


5、XHR Breakpoints
這幾年前端開(kāi)發(fā)發(fā)生了翻天覆地的變化,從當(dāng)初的名不見(jiàn)經(jīng)傳到如今的盛極一時(shí),Ajax驅(qū)動(dòng)Web富應(yīng)用,


移動(dòng)WebApp單頁(yè)應(yīng)用風(fēng)生水起。這一切都離不開(kāi)XMLHttpRequest對(duì)象,而"XHR Breakpoints"正是專(zhuān)為異


步而生的斷點(diǎn)調(diào)試功能。


我們可以通過(guò)"XHR Breakpoints"右側(cè)的"+"號(hào)為異步斷點(diǎn)添加斷點(diǎn)條件,當(dāng)異步請(qǐng)求觸發(fā)時(shí)的URL滿(mǎn)足此


條件,JS邏輯則會(huì)自動(dòng)產(chǎn)生斷點(diǎn)。演示動(dòng)畫(huà)中并沒(méi)有演示到斷點(diǎn)位置,這是因?yàn)?#xff0c;演示使用的是jQuery


封裝好的ajax方法,代碼已經(jīng)過(guò)壓縮,看不到什么效果,而事實(shí)上XHR斷點(diǎn)的產(chǎn)生位置是"xhr.send()"語(yǔ)


句。
XHR斷點(diǎn)的強(qiáng)大之處是可以自定義斷點(diǎn)規(guī)則,這就意味著我們可以針對(duì)某一批、某一個(gè),乃至所有異步請(qǐng)


求進(jìn)行斷點(diǎn)設(shè)置,非常強(qiáng)大。但是,似乎這個(gè)功能在日常開(kāi)發(fā)中用得并不多,至少我用得不多。想想原


因大概有兩點(diǎn):其一,這類(lèi)型的斷點(diǎn)調(diào)試需求在日常業(yè)務(wù)中本身涉及不多;其二,現(xiàn)階段的前端開(kāi)發(fā)大


多基于JS框架進(jìn)行,最基本的jQuery也已經(jīng)對(duì)Ajax進(jìn)行了良好封裝,極少有人自己封裝Ajax方法,而項(xiàng)


目為了減少代碼體積,通常選擇壓縮后的代碼庫(kù),使得XHR斷點(diǎn)跟蹤相對(duì)不那么容易了。
6、Event Listener Breakpoints
事件監(jiān)聽(tīng)器斷點(diǎn),即根據(jù)事件名稱(chēng)進(jìn)行斷點(diǎn)設(shè)置。當(dāng)事件被觸發(fā)時(shí),斷點(diǎn)到事件綁定的位置。事件監(jiān)聽(tīng)


器斷點(diǎn),列出了所有頁(yè)面及腳本事件,包括:鼠標(biāo)、鍵盤(pán)、動(dòng)畫(huà)、定時(shí)器、XHR等等。極大的降低了事件


方面業(yè)務(wù)邏輯的調(diào)試難度。


演示實(shí)例演示了當(dāng)click事件被觸發(fā)時(shí)和當(dāng)setTimeout被設(shè)置時(shí)的斷點(diǎn)效果。實(shí)例顯示,當(dāng)選中click事


件斷點(diǎn)之后,兩個(gè)按鈕的被點(diǎn)擊時(shí)都觸發(fā)了斷點(diǎn),而當(dāng)setTimeout被設(shè)置時(shí),"Set Timer"斷點(diǎn)被觸發(fā)。
調(diào)試,是在項(xiàng)目開(kāi)發(fā)中非常重要的環(huán)節(jié),不僅可以幫助我們快速定位問(wèn)題,還能節(jié)省我們的開(kāi)發(fā)時(shí)間。


熟練掌握各種調(diào)試手段,定當(dāng)為你的職業(yè)發(fā)展帶來(lái)諸多利益,但是,在如此多的調(diào)試手段中,如何選擇


一個(gè)適合自己當(dāng)前應(yīng)用場(chǎng)景的,這需要經(jīng)驗(yàn),需要不斷嘗試積累。
寫(xiě)到這里,基本上可以說(shuō)是傾囊而出了,希望能引起你的注意,希望能夠讓你感到一絲的觸動(dòng),感到一


些似曾相識(shí)。最主要的我還是希望你能夠快速提高自己的技能,讓自己成為技術(shù)牛人!
========

JS高級(jí)調(diào)試技巧:捕獲和分析 JavaScript Error詳解



前端工程師都知道 JavaScript 有基本的異常處理能力。我們可以 throw new Error(),瀏覽器也會(huì)在


我們調(diào)用 API 出錯(cuò)時(shí)拋出異常。但估計(jì)絕大多數(shù)前端工程師都沒(méi)考慮過(guò)收集這些異常信息


反正只要 JavaScript 出錯(cuò)后刷新不復(fù)現(xiàn),那用戶(hù)就可以通過(guò)刷新解決問(wèn)題,瀏覽器不會(huì)崩潰,當(dāng)沒(méi)有


發(fā)生過(guò)好了。這種假設(shè)在 Single Page App 流行之前還是成立的。現(xiàn)在的 Single Page App 運(yùn)行一段


時(shí)間后狀態(tài)復(fù)雜無(wú)比,用戶(hù)可能進(jìn)行了若干輸入操作才來(lái)到這里的,說(shuō)刷新就刷新啊?之前的操作豈不


要完全重做?所以我們還是有必要捕獲和分析這些異常信息的,然后我們就可以修改代碼避免影響用戶(hù)


體驗(yàn)。
捕獲異常的方式
我們自己寫(xiě)的 throw new Error() 想要捕獲當(dāng)然可以捕獲,因?yàn)槲覀兒芮宄?throw 寫(xiě)在哪里了。但是


調(diào)用瀏覽器 API 時(shí)發(fā)生的異常就不一定那么容易捕獲了,有些 API 在標(biāo)準(zhǔn)里就寫(xiě)著會(huì)拋出異常,有些?


API 只有個(gè)別瀏覽器因?yàn)閷?shí)現(xiàn)差異或者有缺陷而拋出異常。對(duì)于前者我們還能通過(guò) try-catch 捕獲,對(duì)


于后者我們必須監(jiān)聽(tīng)全局的異常然后捕獲。
try-catch
如果有些瀏覽器 API 是已知會(huì)拋出異常的,那我們就需要把調(diào)用放到 try-catch 里面,避免因?yàn)槌鲥e(cuò)


而導(dǎo)致整個(gè)程序進(jìn)入非法狀態(tài)。例如說(shuō) window.localStorage 就是這樣的一個(gè) API,在寫(xiě)入數(shù)據(jù)超過(guò)容


量限制后就會(huì)拋出異常,在 Safari 的隱私瀏覽模式下也會(huì)如此。
try {
?localStorage.setItem('date', Date.now());
} catch (error) {
?reportError(error);
}
另一個(gè)常見(jiàn)的 try-catch 適用場(chǎng)景是回調(diào)。因?yàn)榛卣{(diào)函數(shù)的代碼是我們不可控的,代碼質(zhì)量如何,會(huì)不


會(huì)調(diào)用其它會(huì)拋出異常的 API,我們一概不知道。為了不要因?yàn)榛卣{(diào)出錯(cuò)而導(dǎo)致調(diào)用回調(diào)后的其它代碼


無(wú)法執(zhí)行,所以把調(diào)用回到放到 try-catch 里面是必須的。
listeners.forEach(function(listener) {
?try {
?listener();
?} catch (error) {
?reportError(error);
?}
});
window.onerror
對(duì)于 try-catch 覆蓋不到的地方,如果出現(xiàn)異常就只能通過(guò) window.onerror 來(lái)捕獲了。
window.onerror =
?function(errorMessage, scriptURI, lineNumber) {
?reportError({
?message: errorMessage,
?script: scriptURI,
?line: lineNumber
?});
}
注意不要耍小聰明使用 window.addEventListener 或 window.attachEvent 的形式去監(jiān)聽(tīng)?


window.onerror。很多瀏覽器只實(shí)現(xiàn)了 window.onerror,或者是只有 window.onerror 的實(shí)現(xiàn)是標(biāo)準(zhǔn)的


。考慮到標(biāo)準(zhǔn)草案定義的也是 window.onerror,我們使用 window.onerror 就好了。
屬性丟失
假設(shè)我們有一個(gè) reportError 函數(shù)用來(lái)收集捕獲到的異常,然后批量發(fā)送到服務(wù)器端存儲(chǔ)以便查詢(xún)分析


,那么我們會(huì)想要收集哪些信息呢?比較有用的信息包括:錯(cuò)誤類(lèi)型(name)、錯(cuò)誤消息(message)、


腳本文件地址(script)、行號(hào)(line)、列號(hào)(column)、堆棧跟蹤(stack)。如果一個(gè)異常是通過(guò)?


try-catch 捕獲到的,這些信息都在 Error 對(duì)象上(主流瀏覽器都支持),所以 reportError 也能收


集到這些信息。但如果是通過(guò) window.onerror 捕獲到的,我們都知道這個(gè)事件函數(shù)只有 3 個(gè)參數(shù),所


以這 3 個(gè)參數(shù)意外的信息就丟失了。
序列化消息
如果 Error 對(duì)象是我們自己創(chuàng)建的話,那么 error.message 就是由我們控制的。基本上我們把什么放


進(jìn) error.message 里面,window.onerror 的第一個(gè)參數(shù)(message)就會(huì)是什么。(瀏覽器其實(shí)會(huì)略作


修改,例如加上 'Uncaught Error: ' 前綴。)因此我們可以把我們關(guān)注的屬性序列化(例如?


JSON.Stringify)后存放到 error.message 里面,然后在 window.onerror 讀取出來(lái)反序列化就可以了


。當(dāng)然,這僅限于我們自己創(chuàng)建的 Error 對(duì)象。
第五個(gè)參數(shù)
瀏覽器廠商也知道大家在使用 window.onerror 時(shí)受到的限制,所以開(kāi)始往 window.onerror 上面添加


新的參數(shù)。考慮到只有行號(hào)沒(méi)有列號(hào)好像不是很對(duì)稱(chēng)的樣子,IE 首先把列號(hào)加上了,放在第四個(gè)參數(shù)。


然而大家更關(guān)心的是能否拿到完整的堆棧,于是 Firefox 說(shuō)不如把堆棧放在第五個(gè)參數(shù)吧。但 Chrome?


說(shuō)那還不如把整個(gè) Error 對(duì)象放在第五個(gè)參數(shù),大家想讀取什么屬性都可以了,包括自定義屬性。結(jié)果


由于 Chrome 動(dòng)作比較快,在 Chrome 30 實(shí)現(xiàn)了新的 window.onerror 簽名,導(dǎo)致標(biāo)準(zhǔn)草案也就跟著這


樣寫(xiě)了。
window.onerror = function(
?errorMessage,
?scriptURI,
?lineNumber,
?columnNumber,
?error
) {
?if (error) {
?reportError(error);
?} else {
?reportError({
?message: errorMessage,
?script: scriptURI,
?line: lineNumber,
?column: columnNumber
?});
?}
}
屬性正規(guī)化
我們之前討論到的 Error 對(duì)象屬性,其名稱(chēng)都是基于 Chrome 命名方式的,然而不同瀏覽器對(duì) Error?


對(duì)象屬性的命名方式各不相同,例如腳本文件地址在 Chrome 叫做 script 但在 Firefox 叫做?


filename。因此,我們還需要一個(gè)專(zhuān)門(mén)的函數(shù)來(lái)對(duì) Error 對(duì)象進(jìn)行正規(guī)化處理,也就是把不同的屬性名


稱(chēng)都映射到統(tǒng)一的屬性名稱(chēng)上。具體做法可以參考這篇文章。盡管瀏覽器實(shí)現(xiàn)會(huì)更新,但人手維護(hù)一份


這樣的映射表并不會(huì)太難。
類(lèi)似的是堆棧跟蹤(stack)的格式。這個(gè)屬性以純文本的形式保存一份異常在發(fā)生時(shí)的堆棧信息,由于


各個(gè)瀏覽器使用的文本格式不一樣,所以也需要人手維護(hù)一份正則表達(dá),用于從純文本中提取每一幀的


函數(shù)名(identifier)、文件(script)、行號(hào)(line)和列號(hào)(column)。
安全限制
如果你也遇到過(guò)消息為 'Script error.' 的錯(cuò)誤,你會(huì)明白我在說(shuō)什么的,這其實(shí)是瀏覽器針對(duì)不同源


(origin)腳本文件的限制。這個(gè)安全限制的理由是這樣的:假設(shè)一家網(wǎng)銀在用戶(hù)登錄后返回的 HTML?


跟匿名用戶(hù)看到的 HTML 不一樣,一個(gè)第三方網(wǎng)站就能把這家網(wǎng)銀的 URI 放到 script.src 屬性里面。


HTML 當(dāng)然不可能被當(dāng)做 JS 解析啦,所以瀏覽器會(huì)拋出異常,而這個(gè)第三方網(wǎng)站就能通過(guò)解析異常的位


置來(lái)判斷用戶(hù)是否有登錄。為此瀏覽器對(duì)于不同源腳本文件拋出的異常一律進(jìn)行過(guò)濾,過(guò)濾得只剩下?


'Script error.' 這樣一條不變的消息,其它屬性統(tǒng)統(tǒng)消失。
對(duì)于有一定規(guī)模的網(wǎng)站來(lái)說(shuō),腳本文件放在 CDN 上,不同源是很正常的。現(xiàn)在就算是自己做個(gè)小網(wǎng)站,


常見(jiàn)框架如 jQuery 和 Backbone 都能直接引用公共 CDN 上的版本,加速用戶(hù)下載。所以這個(gè)安全限制


確實(shí)造成了一些麻煩,導(dǎo)致我們從 Chrome 和 Firefox 收集到的異常信息都是無(wú)用的 'Script error.'



CORS
想要繞過(guò)這個(gè)限制,只要保證腳本文件和頁(yè)面本身同源即可。但把腳本文件放在不經(jīng) CDN 加速的服務(wù)器


上,豈不降低用戶(hù)下載速度?一個(gè)解決方案是,腳本文件繼續(xù)放在 CDN 上,利用 XMLHttpRequest 通過(guò)?


CORS 把內(nèi)容下載回來(lái),再創(chuàng)建 <script> 標(biāo)簽注入到頁(yè)面當(dāng)中。在頁(yè)面當(dāng)中內(nèi)嵌的代碼當(dāng)然是同源的啦



這說(shuō)起來(lái)很簡(jiǎn)單,但實(shí)現(xiàn)起來(lái)卻有很多細(xì)節(jié)問(wèn)題。用一個(gè)簡(jiǎn)單的例子來(lái)說(shuō):
<script src="http://cdn.com/step1.js"></script>
<script>
?(function step2() {})();
</script>
<script src="http://cdn.com/step3.js"></script>
我們都知道這個(gè) step1、step2、step3 如果存在依賴(lài)關(guān)系的話,則必須嚴(yán)格按照這個(gè)順序執(zhí)行,否則就


可能出錯(cuò)。瀏覽器可以并行請(qǐng)求 step1 和 step3 的文件,但在執(zhí)行時(shí)順序是保證的。如果我們自己通


過(guò) XMLHttpRequest 獲取 step1 和 step3 的文件內(nèi)容,我們就需要自行保證其順序正確性。此外不要


忘記了 step2,在 step1 以非阻塞形式下載的時(shí)候 step2 就可以被執(zhí)行了,所以我們還必須人為干預(yù)?


step2 讓它等待 step1 完成后再執(zhí)行。
如果我們已經(jīng)有一整套工具來(lái)生成網(wǎng)站上不同頁(yè)面的 <script> 標(biāo)簽的話,我們就需要調(diào)整一下這套工


具讓它對(duì) <script> 標(biāo)簽做出改動(dòng):
<script>
?scheduleRemoteScript('http://cdn.com/step1.js');
</script>
<script>
?scheduleInlineScript(function code() {
?(function step2() {})();
?});
</script>
<script>
?scheduleRemoteScript('http://cdn.com/step3.js');
</script>
我們需要實(shí)現(xiàn) scheduleRemoteScript 和 scheduleInlineScript 這兩個(gè)函數(shù),并且保證它們?cè)诘谝粋€(gè)


引用外部腳本文件的 <script> 標(biāo)簽之前就被定義好,然后余下的 <script> 標(biāo)簽都會(huì)被改寫(xiě)成上面這


種形式。注意原本立即執(zhí)行的 step2 函數(shù)被放到了一個(gè)更大的 code 函數(shù)里面了。code 函數(shù)并不會(huì)被


執(zhí)行,它只是一個(gè)容器而已,這樣使得原本 step2 的代碼不需要轉(zhuǎn)義就能保留下來(lái),但又不會(huì)被立即執(zhí)


行。
接下來(lái)我們還需要實(shí)現(xiàn)一套完整的機(jī)制,保證這些由 scheduleRemoteScript 根據(jù)地址下載回來(lái)的文件


內(nèi)容和由 scheduleInlineScript 直接獲取到的代碼能夠按照正確的順序一個(gè)接一個(gè)地執(zhí)行。詳細(xì)的代


碼我就不在這里給出了,大家有興趣可以自己去實(shí)現(xiàn)。
行號(hào)反查
通過(guò) CORS 獲取內(nèi)容再把代碼注入頁(yè)面能夠突破安全限制,但會(huì)引入一個(gè)新的問(wèn)題,那就是行號(hào)沖突。


原本通過(guò) error.script 可以定位到唯一的腳本文件,再通過(guò) error.line 可以定位到唯一的行號(hào)。現(xiàn)


在由于都是頁(yè)面內(nèi)嵌的代碼,多個(gè) <script> 標(biāo)簽并不能通過(guò) error.script 來(lái)區(qū)分,然而每一個(gè)?


<script> 標(biāo)簽內(nèi)部的行號(hào)都是從 1 算起的,結(jié)果就導(dǎo)致我們無(wú)法利用異常信息定位錯(cuò)誤所在的源代碼


位置。
為了避免行號(hào)沖突,我們可以浪費(fèi)一些行號(hào),使得每一個(gè) <script> 標(biāo)簽中有實(shí)際代碼所使用的行號(hào)區(qū)


間互相不重疊。舉個(gè)例子來(lái)說(shuō),假設(shè)每個(gè) <script> 標(biāo)簽中的實(shí)際代碼都不超過(guò) 1000 行,那么我可以


讓第一個(gè) <script> 標(biāo)簽中的代碼占用第 1–1000 行,讓第二個(gè) <script> 標(biāo)簽中的代碼占用第 1001


–2000 行(前面插入 1000 行空行),第三個(gè) <script> 標(biāo)簽種的代碼占用第 2001–3000 行(前面插


入 2000 行空行),以此類(lèi)推。然后我們使用 data-* 屬性記錄這些信息,便于反查。
<script
?data-src="http://cdn.com/step1.js"
?data-line-start="1"
>
?// code for step 1
</script>
<script data-line-start="1001">
?// '\n' * 1000
?// code for step 2
</script>
<script
?data-src="http://cdn.com/step3.js"
?data-line-start="2001"
>
?// '\n' * 2000
?// code for step 3
</script>
經(jīng)過(guò)這樣處理后,如果一個(gè)錯(cuò)誤的 error.line 是 3005 的話,那意味著實(shí)際的 error.script 應(yīng)該是?


'http://cdn.com/step3.js',而實(shí)際的 error.line 則應(yīng)該是 5。我們可以在之前提到的 reportError?


函數(shù)里面完成這項(xiàng)行號(hào)反查工作。
當(dāng)然,由于我們沒(méi)辦法保證每一個(gè)腳本文件只有 1000 行,也有可能有些腳本文件明顯小于 1000 行,


所以其實(shí)不需要固定分配 1000 行的區(qū)間給每一個(gè) <script> 標(biāo)簽。我們可以根據(jù)實(shí)際腳本行數(shù)來(lái)分配


區(qū)間,只要保證每一個(gè) <script> 標(biāo)簽所使用的區(qū)間互不重疊就可以了。
crossorigin 屬性
瀏覽器對(duì)于不同源的內(nèi)容進(jìn)行的安全限制當(dāng)然不僅限于 <script> 標(biāo)簽。既然 XMLHttpRequest 可以通


過(guò) CORS 來(lái)突破這個(gè)限制,為什么直接通過(guò)標(biāo)簽引用的資源就不可以呢?這當(dāng)然是可以的。
針對(duì) <script> 標(biāo)簽引用不同源腳本文件的限制同樣作用于 <img> 標(biāo)簽引用不同源圖片文件。如果一個(gè)?


<img> 標(biāo)簽是不同源的話,一旦在 <canvas> 繪圖時(shí)用到了,該 <canvas> 將變?yōu)橹粚?xiě)狀態(tài),保證網(wǎng)站


不能通過(guò) JavaScript 竊取未授權(quán)的不同源圖片數(shù)據(jù)。后來(lái) <img> 標(biāo)簽通過(guò)引入 crossorigin 屬性解


決了這個(gè)問(wèn)題。如果使用 crossorigin="anonymous",則相當(dāng)于匿名 CORS;如果使用 `crossorigin=“


use-credentials”,則相當(dāng)于帶認(rèn)證的 CORS。
既然 <img> 標(biāo)簽?zāi)苓@樣做,為什么 <script> 標(biāo)簽就不能這樣做?于是瀏覽器廠商就為 <script> 標(biāo)簽


加入了同樣的 crossorigin 屬性用于解決上述安全限制問(wèn)題。現(xiàn)在 Chrome 和 Firefox 對(duì)這個(gè)屬性的


支持是完全沒(méi)有問(wèn)題的。Safari 則會(huì)把 crossorigin="anonymous" 當(dāng)做 crossorigin="use-


credentials" 處理,結(jié)果是如果服務(wù)器只支持匿名 CORS 則 Safari 會(huì)當(dāng)做認(rèn)證失敗。由于 CDN 服務(wù)


器出于性能的考慮被設(shè)計(jì)為只能返回靜態(tài)內(nèi)容,不可能動(dòng)態(tài)的根據(jù)請(qǐng)求返回認(rèn)證 CORS 所需的 HTTP?


Header,Safari 相當(dāng)于不能利用此特性來(lái)解決上述問(wèn)題。
總結(jié)
JavaScript 異常處理看起來(lái)很簡(jiǎn)單,跟其它語(yǔ)言沒(méi)什么區(qū)別,但真的要把異常都捕獲了然后對(duì)屬性做分


析,其實(shí)還不是那么容易的事情。現(xiàn)在盡管有一些第三方服務(wù)提供捕獲 JavaScript 異常的類(lèi) Google?


Analytics 服務(wù),但如果要弄明白其中的細(xì)節(jié)和原理還是必須自己親手做一次。
========

靈活應(yīng)用js調(diào)試技巧解決樣式問(wèn)題的步驟分享



在很多時(shí)候,前端開(kāi)發(fā)人員使用JS腳本,對(duì)頁(yè)面Dom結(jié)構(gòu)或者是樣式做出了修改,會(huì)造成一些意想不到的


bug


由于種種原因,例如:代碼邏輯復(fù)雜、時(shí)間久了遺忘處理細(xì)節(jié)、或者根本就是接手修改別人遺留的bug,


在這種情況下,debug就會(huì)變成一件頭疼的事情。?


在此分享一些JS調(diào)試方面的技巧,針對(duì)各種疑難雜癥,往往能起到較好的效果。?


Step 1:檢查服務(wù)器直接render出來(lái)的內(nèi)容?


    使用查看源文件的方式,這一步首先明確,頁(yè)面HTML片段是否在服務(wù)器端就已經(jīng)不正常了。?


Step 2:比較實(shí)際的HTML內(nèi)容和服務(wù)器render出來(lái)的原始內(nèi)容之間的差異?


    可以使用一些前端工具(例如:IE下的開(kāi)發(fā)人員工具、Firebug、Chrome的開(kāi)發(fā)人員工具等),


實(shí)時(shí)查看當(dāng)前HTML片段內(nèi)容?


Step 3:在合適的位置增加debugger?


    例如:先找出大概可能出問(wèn)題的js代碼,在合適的地方加debugger,或者是使用工具增加類(lèi)似


于“在屬性被修改時(shí)中斷”的斷點(diǎn),例如實(shí)際的HTML比原始內(nèi)容多出了一個(gè)width屬性?


Step 4:運(yùn)行你的頁(yè)面,進(jìn)入中斷,并檢查js調(diào)用堆棧(關(guān)鍵的一步)?


    推薦使用IE支持的Visual Studio調(diào)試器(需要先設(shè)置IE:取消“禁用腳本調(diào)試”),這時(shí)基本


就能確定是哪個(gè)js方法修改了樣式
========

總結(jié)

以上是生活随笔為你收集整理的js断点和调试学习总结3的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

精品日本一区二区三区在线观看 | 一本久久a久久精品vr综合 | 久久久久久av无码免费看大片 | 国产小呦泬泬99精品 | 中文字幕日韩精品一区二区三区 | 性欧美videos高清精品 | 男女性色大片免费网站 | 亚洲欧洲日本无在线码 | 波多野结衣一区二区三区av免费 | 人人妻人人澡人人爽欧美一区 | 在线精品国产一区二区三区 | 国产一区二区不卡老阿姨 | 国产欧美精品一区二区三区 | 波多野结衣乳巨码无在线观看 | 久久精品国产日本波多野结衣 | 国产网红无码精品视频 | 牲交欧美兽交欧美 | 狠狠cao日日穞夜夜穞av | 国产成人精品三级麻豆 | 中文字幕人妻丝袜二区 | 精品无人国产偷自产在线 | 熟女少妇人妻中文字幕 | 中文字幕无码乱人伦 | 午夜精品一区二区三区的区别 | 国产无遮挡又黄又爽免费视频 | 久久午夜无码鲁丝片 | 日本熟妇大屁股人妻 | 国产精品办公室沙发 | 无码精品人妻一区二区三区av | 国产色xx群视频射精 | 日韩av激情在线观看 | 天天综合网天天综合色 | 久久www免费人成人片 | 在线成人www免费观看视频 | 欧美日韩一区二区综合 | 激情亚洲一区国产精品 | 亚洲aⅴ无码成人网站国产app | 中文字幕乱码亚洲无线三区 | 美女张开腿让人桶 | 日本护士毛茸茸高潮 | 午夜精品久久久内射近拍高清 | 性欧美牲交xxxxx视频 | 激情内射亚州一区二区三区爱妻 | 亚洲精品中文字幕久久久久 | 久久亚洲国产成人精品性色 | 超碰97人人做人人爱少妇 | 人妻少妇精品无码专区动漫 | 亚洲无人区一区二区三区 | 久热国产vs视频在线观看 | 日韩精品一区二区av在线 | 久久久久成人片免费观看蜜芽 | 无码乱肉视频免费大全合集 | 无套内谢的新婚少妇国语播放 | 高清国产亚洲精品自在久久 | 日韩成人一区二区三区在线观看 | 亚洲综合伊人久久大杳蕉 | 免费无码肉片在线观看 | 一本久道久久综合狠狠爱 | 少妇人妻av毛片在线看 | 色五月丁香五月综合五月 | av无码久久久久不卡免费网站 | 亚洲色在线无码国产精品不卡 | 成人三级无码视频在线观看 | 超碰97人人做人人爱少妇 | 国产精品欧美成人 | 天天摸天天碰天天添 | 成 人 网 站国产免费观看 | 国产区女主播在线观看 | 亚洲国产午夜精品理论片 | 亚洲人成影院在线无码按摩店 | 亚洲a无码综合a国产av中文 | 天天躁日日躁狠狠躁免费麻豆 | 麻豆蜜桃av蜜臀av色欲av | 大屁股大乳丰满人妻 | 精品国产一区二区三区四区 | 亚洲一区二区三区香蕉 | 大胆欧美熟妇xx | 国产成人精品视频ⅴa片软件竹菊 | 男人扒开女人内裤强吻桶进去 | 亚洲中文字幕无码一久久区 | 精品日本一区二区三区在线观看 | 国产午夜亚洲精品不卡下载 | 性欧美熟妇videofreesex | 天堂一区人妻无码 | 亚洲一区二区三区 | 国产一区二区三区精品视频 | 久久99精品国产麻豆 | 国产精品美女久久久久av爽李琼 | 亚洲爆乳精品无码一区二区三区 | 中文精品久久久久人妻不卡 | 爆乳一区二区三区无码 | 东京无码熟妇人妻av在线网址 | 日本熟妇大屁股人妻 | 国产网红无码精品视频 | 内射欧美老妇wbb | 午夜精品久久久久久久 | 人妻尝试又大又粗久久 | 日韩 欧美 动漫 国产 制服 | 内射巨臀欧美在线视频 | 我要看www免费看插插视频 | 老子影院午夜伦不卡 | 国产日产欧产精品精品app | 丰满岳乱妇在线观看中字无码 | 久久久久亚洲精品男人的天堂 | 国产激情艳情在线看视频 | 中文字幕人妻无码一区二区三区 | 亚洲成av人片在线观看无码不卡 | 亚洲熟妇自偷自拍另类 | 久久午夜夜伦鲁鲁片无码免费 | 久久人人爽人人人人片 | 九月婷婷人人澡人人添人人爽 | 亚洲人亚洲人成电影网站色 | 亚洲欧美国产精品久久 | 中文字幕无码av波多野吉衣 | 牲欲强的熟妇农村老妇女 | 97se亚洲精品一区 | 亚欧洲精品在线视频免费观看 | 男女猛烈xx00免费视频试看 | 午夜性刺激在线视频免费 | 久久zyz资源站无码中文动漫 | 欧美丰满少妇xxxx性 | 亚洲 欧美 激情 小说 另类 | 国产va免费精品观看 | 熟妇女人妻丰满少妇中文字幕 | 色综合久久久无码网中文 | 四虎影视成人永久免费观看视频 | 熟妇女人妻丰满少妇中文字幕 | 国产绳艺sm调教室论坛 | 亚洲高清偷拍一区二区三区 | 亚洲成熟女人毛毛耸耸多 | 国产精品国产自线拍免费软件 | 牲交欧美兽交欧美 | 国产精品办公室沙发 | 久久亚洲精品中文字幕无男同 | 色五月丁香五月综合五月 | 亚洲 日韩 欧美 成人 在线观看 | 东京热男人av天堂 | 人人妻人人澡人人爽人人精品浪潮 | 国产农村妇女高潮大叫 | 色狠狠av一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 久久精品国产一区二区三区 | 久久亚洲a片com人成 | 牛和人交xxxx欧美 | 无遮挡啪啪摇乳动态图 | 国产精品自产拍在线观看 | 国产精品-区区久久久狼 | 国产一区二区三区影院 | 亚洲精品午夜无码电影网 | 久久午夜无码鲁丝片秋霞 | 无码午夜成人1000部免费视频 | 偷窥村妇洗澡毛毛多 | 蜜臀aⅴ国产精品久久久国产老师 | 18禁止看的免费污网站 | 欧美人与善在线com | 国产精品人人爽人人做我的可爱 | 欧美日韩久久久精品a片 | 国产精品久久久午夜夜伦鲁鲁 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 亚洲成色www久久网站 | 欧美老妇交乱视频在线观看 | 综合人妻久久一区二区精品 | 国产av人人夜夜澡人人爽麻豆 | 午夜精品一区二区三区的区别 | 国产人妻人伦精品 | 初尝人妻少妇中文字幕 | 九九在线中文字幕无码 | 久久精品国产一区二区三区肥胖 | 少妇愉情理伦片bd | 少妇人妻偷人精品无码视频 | 水蜜桃亚洲一二三四在线 | 亚洲国产午夜精品理论片 | 精品一区二区不卡无码av | 激情内射亚州一区二区三区爱妻 | 婷婷综合久久中文字幕蜜桃三电影 | 国产特级毛片aaaaaaa高清 | 久久亚洲精品成人无码 | 99精品久久毛片a片 | 国产精品高潮呻吟av久久 | 丁香啪啪综合成人亚洲 | 久热国产vs视频在线观看 | 精品aⅴ一区二区三区 | 狂野欧美性猛交免费视频 | 伊人色综合久久天天小片 | 丝袜 中出 制服 人妻 美腿 | 日日天日日夜日日摸 | 成人无码视频在线观看网站 | 国产精品va在线观看无码 | 玩弄中年熟妇正在播放 | 亚洲人成网站在线播放942 | 宝宝好涨水快流出来免费视频 | 色综合久久88色综合天天 | 在线观看国产午夜福利片 | 女人色极品影院 | 精品aⅴ一区二区三区 | 日本熟妇乱子伦xxxx | 国産精品久久久久久久 | 少妇太爽了在线观看 | 中文字幕人妻丝袜二区 | 国产性生大片免费观看性 | 无码人妻av免费一区二区三区 | 亚洲码国产精品高潮在线 | 国产精品怡红院永久免费 | 国语自产偷拍精品视频偷 | 久久99久久99精品中文字幕 | 老子影院午夜伦不卡 | 国产成人综合美国十次 | 亚洲日韩av一区二区三区四区 | 正在播放老肥熟妇露脸 | 内射白嫩少妇超碰 | 中文字幕久久久久人妻 | 亚洲国产精品毛片av不卡在线 | 一本久道久久综合婷婷五月 | 青草视频在线播放 | 300部国产真实乱 | 少妇性俱乐部纵欲狂欢电影 | 毛片内射-百度 | 亚洲国产欧美国产综合一区 | 国産精品久久久久久久 | 欧美成人高清在线播放 | 人妻互换免费中文字幕 | 亚洲爆乳大丰满无码专区 | 久久亚洲精品中文字幕无男同 | 丰满诱人的人妻3 | 野狼第一精品社区 | 国产精品高潮呻吟av久久4虎 | 日日天干夜夜狠狠爱 | 亚洲精品国产a久久久久久 | 久久精品中文字幕一区 | 天下第一社区视频www日本 | 人人妻在人人 | 无码帝国www无码专区色综合 | 国产欧美熟妇另类久久久 | ass日本丰满熟妇pics | 一本久久a久久精品vr综合 | 日欧一片内射va在线影院 | 国精品人妻无码一区二区三区蜜柚 | 精品久久久久久人妻无码中文字幕 | 永久免费观看美女裸体的网站 | 亚洲日韩一区二区三区 | 荫蒂添的好舒服视频囗交 | 亚洲成a人片在线观看无码 | 国产人妻久久精品二区三区老狼 | 综合激情五月综合激情五月激情1 | 国产电影无码午夜在线播放 | 性色av无码免费一区二区三区 | 亚洲狠狠婷婷综合久久 | 性生交大片免费看l | 国产精品怡红院永久免费 | 蜜桃无码一区二区三区 | 人人妻人人澡人人爽人人精品 | 爽爽影院免费观看 | 日韩精品一区二区av在线 | 99精品视频在线观看免费 | 啦啦啦www在线观看免费视频 | 国产亚洲精品久久久久久 | 日本丰满熟妇videos | 久久精品无码一区二区三区 | 亚洲欧美国产精品久久 | av无码电影一区二区三区 | 国产精品鲁鲁鲁 | aⅴ亚洲 日韩 色 图网站 播放 | 免费网站看v片在线18禁无码 | 国产一区二区三区四区五区加勒比 | 久久国产自偷自偷免费一区调 | 国产精品国产三级国产专播 | 亚洲无人区一区二区三区 | 少妇无码吹潮 | 国产sm调教视频在线观看 | 国产超级va在线观看视频 | 国産精品久久久久久久 | 国产九九九九九九九a片 | 午夜无码区在线观看 | 久久无码中文字幕免费影院蜜桃 | 狂野欧美性猛交免费视频 | 中文字幕无码免费久久99 | 国产精品亚洲lv粉色 | 国产精品久久久 | 国产精品va在线观看无码 | 中文字幕乱码人妻无码久久 | 亚洲毛片av日韩av无码 | 中文字幕无码热在线视频 | 日日碰狠狠躁久久躁蜜桃 | 国产精品无套呻吟在线 | 无码国内精品人妻少妇 | 少妇太爽了在线观看 | 亚洲一区二区三区 | 国产成人亚洲综合无码 | 少妇愉情理伦片bd | 国产精品无码一区二区桃花视频 | 任你躁国产自任一区二区三区 | 人妻少妇精品久久 | 亚洲一区二区三区无码久久 | 少妇性荡欲午夜性开放视频剧场 | 国产午夜福利100集发布 | 高潮毛片无遮挡高清免费 | 香蕉久久久久久av成人 | 国产乱子伦视频在线播放 | 亚洲国产精品无码久久久久高潮 | 国产精品人妻一区二区三区四 | 国产综合久久久久鬼色 | 97夜夜澡人人爽人人喊中国片 | 国产精品国产自线拍免费软件 | 国产偷抇久久精品a片69 | 最新国产乱人伦偷精品免费网站 | 欧美人与善在线com | 欧美丰满熟妇xxxx性ppx人交 | 波多野结衣乳巨码无在线观看 | 国产精品办公室沙发 | 国产熟女一区二区三区四区五区 | 欧美 亚洲 国产 另类 | 99久久久无码国产aaa精品 | 久久久婷婷五月亚洲97号色 | 日本一区二区三区免费播放 | 国产成人综合在线女婷五月99播放 | 97久久超碰中文字幕 | 色诱久久久久综合网ywww | 日本一区二区三区免费高清 | yw尤物av无码国产在线观看 | 中文字幕乱码亚洲无线三区 | 国产乱人伦偷精品视频 | 性生交片免费无码看人 | 男人和女人高潮免费网站 | 最近免费中文字幕中文高清百度 | 亚洲中文字幕成人无码 | 国产又粗又硬又大爽黄老大爷视 | 亚洲成熟女人毛毛耸耸多 | 久久久久久久久蜜桃 | 亚洲伊人久久精品影院 | 波多野结衣乳巨码无在线观看 | 在线a亚洲视频播放在线观看 | 国产在线一区二区三区四区五区 | 精品一区二区三区无码免费视频 | 亚洲精品综合五月久久小说 | 无遮挡啪啪摇乳动态图 | 欧美真人作爱免费视频 | 久久精品国产一区二区三区肥胖 | 亚洲精品一区二区三区大桥未久 | 国产精品怡红院永久免费 | 中文字幕无线码 | 亚洲国产欧美日韩精品一区二区三区 | 九九综合va免费看 | 午夜成人1000部免费视频 | 国产成人无码av片在线观看不卡 | 秋霞成人午夜鲁丝一区二区三区 | 精品久久综合1区2区3区激情 | 国产亚av手机在线观看 | 亚洲日本一区二区三区在线 | 亚洲日韩精品欧美一区二区 | 色 综合 欧美 亚洲 国产 | 国产亚洲精品久久久久久国模美 | 蜜桃无码一区二区三区 | 精品久久久久久人妻无码中文字幕 | 老熟女乱子伦 | 精品午夜福利在线观看 | 水蜜桃色314在线观看 | 日韩欧美成人免费观看 | 超碰97人人做人人爱少妇 | 日韩精品久久久肉伦网站 | 精品国产青草久久久久福利 | 精品少妇爆乳无码av无码专区 | 东京一本一道一二三区 | 国产在线一区二区三区四区五区 | 无码一区二区三区在线观看 | 国产激情一区二区三区 | 久久亚洲中文字幕精品一区 | 色婷婷香蕉在线一区二区 | 久久久久人妻一区精品色欧美 | 欧美精品无码一区二区三区 | 亚洲国产精华液网站w | 亚洲精品国产第一综合99久久 | 免费男性肉肉影院 | 人人妻人人澡人人爽精品欧美 | 无码av中文字幕免费放 | v一区无码内射国产 | 久久久久久久久888 | 亚洲七七久久桃花影院 | 日本一区二区三区免费播放 | 麻豆国产97在线 | 欧洲 | 99久久亚洲精品无码毛片 | 小泽玛莉亚一区二区视频在线 | 初尝人妻少妇中文字幕 | 特黄特色大片免费播放器图片 | 国产午夜精品一区二区三区嫩草 | 亚洲精品久久久久久久久久久 | 色综合天天综合狠狠爱 | www国产亚洲精品久久网站 | 丰满人妻一区二区三区免费视频 | 国产精品第一国产精品 | 老司机亚洲精品影院无码 | 麻豆av传媒蜜桃天美传媒 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 噜噜噜亚洲色成人网站 | 亚洲欧美精品伊人久久 | 亚洲熟熟妇xxxx | 久久久久亚洲精品中文字幕 | 亚洲区小说区激情区图片区 | 伊人久久婷婷五月综合97色 | 天天摸天天碰天天添 | 无码国产色欲xxxxx视频 | 欧美野外疯狂做受xxxx高潮 | 欧美人与禽zoz0性伦交 | 国产免费久久久久久无码 | 亚洲精品中文字幕久久久久 | 亚洲人交乣女bbw | 麻豆精品国产精华精华液好用吗 | 中文字幕无码人妻少妇免费 | 国产精品自产拍在线观看 | 国产香蕉尹人综合在线观看 | 亚洲精品综合一区二区三区在线 | 久久久久久亚洲精品a片成人 | www国产精品内射老师 | 兔费看少妇性l交大片免费 | 国产av无码专区亚洲awww | 男女作爱免费网站 | 无码人妻久久一区二区三区不卡 | 免费无码肉片在线观看 | 国产精品福利视频导航 | 强开小婷嫩苞又嫩又紧视频 | 啦啦啦www在线观看免费视频 | 久久99精品国产麻豆蜜芽 | 永久免费精品精品永久-夜色 | 亚洲日韩av一区二区三区中文 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 一个人免费观看的www视频 | 天堂久久天堂av色综合 | 欧美日本免费一区二区三区 | 水蜜桃亚洲一二三四在线 | 欧洲极品少妇 | 精品成在人线av无码免费看 | 色窝窝无码一区二区三区色欲 | 日韩人妻无码一区二区三区久久99 | 2020久久香蕉国产线看观看 | 欧美zoozzooz性欧美 | 少妇高潮喷潮久久久影院 | 国产精品久久久久影院嫩草 | 成人免费无码大片a毛片 | 欧美35页视频在线观看 | 国产精品第一区揄拍无码 | 午夜熟女插插xx免费视频 | 欧美变态另类xxxx | 丰满人妻精品国产99aⅴ | 国语自产偷拍精品视频偷 | 无码人妻少妇伦在线电影 | 少妇激情av一区二区 | 人妻aⅴ无码一区二区三区 | 中文字幕乱码人妻无码久久 | 精品无码一区二区三区爱欲 | 久久综合香蕉国产蜜臀av | 久久97精品久久久久久久不卡 | 欧美35页视频在线观看 | 久久久久久九九精品久 | 无码任你躁久久久久久久 | 国产偷自视频区视频 | 小sao货水好多真紧h无码视频 | 欧美丰满熟妇xxxx性ppx人交 | 麻豆人妻少妇精品无码专区 | 欧美刺激性大交 | 亚洲日本va午夜在线电影 | 亚洲一区二区三区含羞草 | 无人区乱码一区二区三区 | 国产一区二区不卡老阿姨 | 亚洲爆乳精品无码一区二区三区 | 国产极品美女高潮无套在线观看 | 亚洲 另类 在线 欧美 制服 | 亚洲国产精品无码一区二区三区 | 久久久无码中文字幕久... | 无遮无挡爽爽免费视频 | 亚洲成熟女人毛毛耸耸多 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产av一区二区精品久久凹凸 | 亚洲精品无码人妻无码 | 久久久精品456亚洲影院 | 久久这里只有精品视频9 | 欧美兽交xxxx×视频 | 伊人久久大香线蕉午夜 | 台湾无码一区二区 | 图片小说视频一区二区 | 中文字幕精品av一区二区五区 | 色一情一乱一伦一视频免费看 | 久久精品人人做人人综合 | 亚洲va中文字幕无码久久不卡 | 18精品久久久无码午夜福利 | 99久久久无码国产aaa精品 | 99久久99久久免费精品蜜桃 | 未满成年国产在线观看 | 亚洲国精产品一二二线 | 久久精品国产99久久6动漫 | 日本精品少妇一区二区三区 | 亚洲 日韩 欧美 成人 在线观看 | 日日噜噜噜噜夜夜爽亚洲精品 | 99麻豆久久久国产精品免费 | 正在播放东北夫妻内射 | 日本精品高清一区二区 | 日本精品少妇一区二区三区 | 亚洲国产精品一区二区美利坚 | 国产亚洲日韩欧美另类第八页 | 色情久久久av熟女人妻网站 | 日本一区二区三区免费播放 | 四虎国产精品免费久久 | 国产av一区二区精品久久凹凸 | 黑人大群体交免费视频 | 蜜桃无码一区二区三区 | 97se亚洲精品一区 | 国产麻豆精品精东影业av网站 | 精品国产av色一区二区深夜久久 | 老熟妇乱子伦牲交视频 | 曰本女人与公拘交酡免费视频 | 精品成在人线av无码免费看 | 精品无码国产自产拍在线观看蜜 | 国产av无码专区亚洲a∨毛片 | 国产人妻精品一区二区三区 | 久久精品99久久香蕉国产色戒 | 在教室伦流澡到高潮hnp视频 | 亚洲热妇无码av在线播放 | 国产又爽又猛又粗的视频a片 | 人人妻人人澡人人爽欧美一区 | 色婷婷欧美在线播放内射 | 亚洲国产高清在线观看视频 | 永久免费观看美女裸体的网站 | 国产性生交xxxxx无码 | 亚洲国产精品一区二区美利坚 | 女人和拘做爰正片视频 | 精品国产成人一区二区三区 | 麻花豆传媒剧国产免费mv在线 | 少妇愉情理伦片bd | 在线а√天堂中文官网 | 久久天天躁狠狠躁夜夜免费观看 | 色综合天天综合狠狠爱 | 日日鲁鲁鲁夜夜爽爽狠狠 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国产美女极度色诱视频www | 老熟女乱子伦 | 丰满少妇人妻久久久久久 | 动漫av一区二区在线观看 | 国产精品香蕉在线观看 | 丝袜 中出 制服 人妻 美腿 | 中文字幕乱妇无码av在线 | 国产亚洲精品久久久久久 | 台湾无码一区二区 | 亚洲精品一区二区三区在线观看 | 色一情一乱一伦 | 99久久精品日本一区二区免费 | 无码播放一区二区三区 | 欧美日本免费一区二区三区 | 天天拍夜夜添久久精品 | 精品国偷自产在线视频 | 国产激情无码一区二区app | 美女黄网站人色视频免费国产 | 国产精品高潮呻吟av久久 | 99久久无码一区人妻 | 国产口爆吞精在线视频 | 国产精品人人爽人人做我的可爱 | 国产午夜手机精彩视频 | 国产黄在线观看免费观看不卡 | 亚洲一区二区三区含羞草 | 亚洲一区二区三区含羞草 | 天天摸天天碰天天添 | 亚洲国产成人a精品不卡在线 | 免费男性肉肉影院 | 亚洲综合无码一区二区三区 | 亚洲色欲色欲天天天www | 人人妻人人澡人人爽人人精品浪潮 | 日韩少妇白浆无码系列 | 麻豆蜜桃av蜜臀av色欲av | 亚洲一区二区三区含羞草 | 亚洲欧洲无卡二区视頻 | 性生交大片免费看女人按摩摩 | 最新国产麻豆aⅴ精品无码 | 精品一区二区三区波多野结衣 | 亚洲精品国产第一综合99久久 | 久久综合久久自在自线精品自 | 亚洲色欲色欲天天天www | 999久久久国产精品消防器材 | 无码帝国www无码专区色综合 | 国产av无码专区亚洲a∨毛片 | aⅴ在线视频男人的天堂 | 成年女人永久免费看片 | 亚欧洲精品在线视频免费观看 | 国产97色在线 | 免 | 国产精品久久久久久久9999 | 久久人人爽人人爽人人片ⅴ | 牲欲强的熟妇农村老妇女视频 | 国产精品资源一区二区 | 狠狠色欧美亚洲狠狠色www | 亚无码乱人伦一区二区 | 国产网红无码精品视频 | 国产精品亚洲lv粉色 | 欧美老人巨大xxxx做受 | 亚洲国产精品美女久久久久 | 九九热爱视频精品 | 国产亚洲精品久久久ai换 | 在线播放亚洲第一字幕 | 欧美三级a做爰在线观看 | 久青草影院在线观看国产 | 亚洲色www成人永久网址 | 大地资源中文第3页 | 性做久久久久久久免费看 | 国产精品高潮呻吟av久久 | 国产女主播喷水视频在线观看 | 久久精品国产一区二区三区肥胖 | 人妻有码中文字幕在线 | 男女作爱免费网站 | 18禁黄网站男男禁片免费观看 | 极品嫩模高潮叫床 | 色综合久久久久综合一本到桃花网 | 一本一道久久综合久久 | 少妇人妻大乳在线视频 | 亚洲一区二区三区播放 | 国产真实乱对白精彩久久 | 无套内谢老熟女 | 日韩精品一区二区av在线 | 草草网站影院白丝内射 | 少妇无码av无码专区在线观看 | 欧洲美熟女乱又伦 | 乱人伦人妻中文字幕无码久久网 | 久久成人a毛片免费观看网站 | 扒开双腿疯狂进出爽爽爽视频 | 大乳丰满人妻中文字幕日本 | 精品国产av色一区二区深夜久久 | 精品久久久无码人妻字幂 | 久久精品人人做人人综合试看 | 成人免费视频一区二区 | 妺妺窝人体色www在线小说 | 乱码午夜-极国产极内射 | ass日本丰满熟妇pics | 中文字幕av日韩精品一区二区 | 亚洲一区二区三区国产精华液 | 亚洲欧洲中文日韩av乱码 | 又大又紧又粉嫩18p少妇 | 日产精品高潮呻吟av久久 | 丰满岳乱妇在线观看中字无码 | 国产精品高潮呻吟av久久4虎 | 久久久婷婷五月亚洲97号色 | 好爽又高潮了毛片免费下载 | 一本久道久久综合狠狠爱 | 强伦人妻一区二区三区视频18 | 日韩亚洲欧美精品综合 | 无码午夜成人1000部免费视频 | 无码av最新清无码专区吞精 | 午夜免费福利小电影 | 超碰97人人做人人爱少妇 | 欧美精品无码一区二区三区 | 亚洲精品国偷拍自产在线麻豆 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 色五月五月丁香亚洲综合网 | 少妇无码吹潮 | 午夜福利一区二区三区在线观看 | 成人精品视频一区二区 | 中国女人内谢69xxxx | 丰满岳乱妇在线观看中字无码 | 亚洲色在线无码国产精品不卡 | 国产精品理论片在线观看 | 欧美兽交xxxx×视频 | 日本丰满护士爆乳xxxx | 日韩少妇白浆无码系列 | 久久精品丝袜高跟鞋 | 伊人色综合久久天天小片 | 亚洲小说春色综合另类 | 99精品视频在线观看免费 | 偷窥村妇洗澡毛毛多 | 四虎国产精品一区二区 | 国产在热线精品视频 | 欧美变态另类xxxx | 国产人妻精品一区二区三区 | 久久精品丝袜高跟鞋 | 99er热精品视频 | 内射欧美老妇wbb | 亚洲日韩av片在线观看 | 久久精品人人做人人综合 | 无码av岛国片在线播放 | 久久久久久九九精品久 | 俺去俺来也在线www色官网 | 久久久久成人片免费观看蜜芽 | 夜夜夜高潮夜夜爽夜夜爰爰 | 少妇太爽了在线观看 | 久久午夜无码鲁丝片秋霞 | 东京热一精品无码av | 国产无av码在线观看 | 国语自产偷拍精品视频偷 | 精品国产国产综合精品 | 久久国产精品精品国产色婷婷 | 亲嘴扒胸摸屁股激烈网站 | 久久精品女人的天堂av | 高潮毛片无遮挡高清免费 | 色偷偷人人澡人人爽人人模 | 奇米影视888欧美在线观看 | 亚洲色偷偷偷综合网 | 精品久久综合1区2区3区激情 | 色婷婷久久一区二区三区麻豆 | 天海翼激烈高潮到腰振不止 | 性色av无码免费一区二区三区 | 玩弄中年熟妇正在播放 | 国产真实夫妇视频 | 国产av人人夜夜澡人人爽麻豆 | 麻花豆传媒剧国产免费mv在线 | 97se亚洲精品一区 | 国产午夜无码精品免费看 | 国产在线无码精品电影网 | 一本无码人妻在中文字幕免费 | 一本精品99久久精品77 | 日日天日日夜日日摸 | 国产精品久久国产三级国 | 日韩少妇内射免费播放 | 樱花草在线播放免费中文 | 又大又硬又爽免费视频 | 日产国产精品亚洲系列 | av小次郎收藏 | 欧美怡红院免费全部视频 | 激情亚洲一区国产精品 | a片免费视频在线观看 | 国产偷国产偷精品高清尤物 | 国产精品久久久久久亚洲影视内衣 | 日本饥渴人妻欲求不满 | 欧美黑人性暴力猛交喷水 | 国内少妇偷人精品视频 | 丝袜足控一区二区三区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 精品无人区无码乱码毛片国产 | 亚洲啪av永久无码精品放毛片 | 国语自产偷拍精品视频偷 | 我要看www免费看插插视频 | 在线精品国产一区二区三区 | 沈阳熟女露脸对白视频 | 亚洲熟悉妇女xxx妇女av | 精品人妻人人做人人爽夜夜爽 | 无码人妻少妇伦在线电影 | 国产精品va在线观看无码 | 麻豆av传媒蜜桃天美传媒 | 精品人妻人人做人人爽 | 国产精品久久久 | 天天做天天爱天天爽综合网 | 人人妻人人澡人人爽欧美一区 | 麻豆国产人妻欲求不满谁演的 | 国产一区二区三区四区五区加勒比 | 久久熟妇人妻午夜寂寞影院 | 少妇性l交大片 | 久久综合给久久狠狠97色 | 国产农村妇女高潮大叫 | 中文字幕无码人妻少妇免费 | 国产精品视频免费播放 | 亚洲欧洲日本无在线码 | 最近免费中文字幕中文高清百度 | 成人一在线视频日韩国产 | 爽爽影院免费观看 | 精品人妻av区 | 夜精品a片一区二区三区无码白浆 | 国产凸凹视频一区二区 | 亚洲自偷自拍另类第1页 | 久久无码中文字幕免费影院蜜桃 | 色综合天天综合狠狠爱 | 亚洲欧美国产精品专区久久 | 欧美35页视频在线观看 | 99国产精品白浆在线观看免费 | 日本va欧美va欧美va精品 | 欧美丰满老熟妇xxxxx性 | 俄罗斯老熟妇色xxxx | 国产精品欧美成人 | 九九久久精品国产免费看小说 | 精品人妻人人做人人爽夜夜爽 | 久久99久久99精品中文字幕 | 成人无码影片精品久久久 | aa片在线观看视频在线播放 | 麻豆国产97在线 | 欧洲 | 亚洲va中文字幕无码久久不卡 | 国产精品无码成人午夜电影 | 国产精品无码mv在线观看 | 欧美人与禽猛交狂配 | 亚洲国产一区二区三区在线观看 | 伊人久久大香线蕉亚洲 | 男人和女人高潮免费网站 | 西西人体www44rt大胆高清 | 亚洲一区二区三区播放 | 日本va欧美va欧美va精品 | 99精品无人区乱码1区2区3区 | 日本一卡二卡不卡视频查询 | 日产精品高潮呻吟av久久 | 日韩欧美群交p片內射中文 | 98国产精品综合一区二区三区 | 宝宝好涨水快流出来免费视频 | 精品一区二区三区波多野结衣 | 免费无码一区二区三区蜜桃大 | 色妞www精品免费视频 | 久久99国产综合精品 | 精品一二三区久久aaa片 | 亚洲区小说区激情区图片区 | 一个人免费观看的www视频 | 男人和女人高潮免费网站 | 成人精品视频一区二区三区尤物 | 成 人影片 免费观看 | 狂野欧美性猛交免费视频 | 中文无码精品a∨在线观看不卡 | 亚洲熟妇色xxxxx欧美老妇y | 国产亚洲美女精品久久久2020 | 西西人体www44rt大胆高清 | 无码人妻av免费一区二区三区 | 牲欲强的熟妇农村老妇女 | 东京热无码av男人的天堂 | 无码人妻精品一区二区三区下载 | 少妇厨房愉情理9仑片视频 | 国产精品无码永久免费888 | 亚洲成av人片在线观看无码不卡 | 精品无码av一区二区三区 | 亚洲国产欧美日韩精品一区二区三区 | 一本色道婷婷久久欧美 | 无码人妻精品一区二区三区不卡 | 成人动漫在线观看 | 天下第一社区视频www日本 | av在线亚洲欧洲日产一区二区 | 欧美国产亚洲日韩在线二区 | 超碰97人人做人人爱少妇 | 丰满肥臀大屁股熟妇激情视频 | 美女毛片一区二区三区四区 | 国产亚洲日韩欧美另类第八页 | 日韩少妇白浆无码系列 | 少妇厨房愉情理9仑片视频 | 成人欧美一区二区三区 | 亚洲精品国产第一综合99久久 | 亚洲高清偷拍一区二区三区 | 欧美人与动性行为视频 | 国产午夜精品一区二区三区嫩草 | 亚洲精品久久久久avwww潮水 | 亚洲自偷自拍另类第1页 | 亚洲国产精品无码久久久久高潮 | 精品国产一区二区三区av 性色 | 国产成人精品三级麻豆 | 成人性做爰aaa片免费看不忠 | 在线观看国产一区二区三区 | 亚洲欧洲无卡二区视頻 | 国产乱人偷精品人妻a片 | 帮老师解开蕾丝奶罩吸乳网站 | 国产疯狂伦交大片 | 一本一道久久综合久久 | 好爽又高潮了毛片免费下载 | 欧美色就是色 | 少妇人妻大乳在线视频 | 精品欧美一区二区三区久久久 | 午夜无码人妻av大片色欲 | 国产成人无码专区 | 激情爆乳一区二区三区 | 亚洲阿v天堂在线 | 久久久久国色av免费观看性色 | 久久亚洲日韩精品一区二区三区 | 亚洲aⅴ无码成人网站国产app | 毛片内射-百度 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲第一网站男人都懂 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久久久精品人妻久久影视 | 国产区女主播在线观看 | 精品久久综合1区2区3区激情 | 亚洲欧美精品伊人久久 | 国产手机在线αⅴ片无码观看 | 久久天天躁狠狠躁夜夜免费观看 | 99久久精品日本一区二区免费 | 熟妇人妻中文av无码 | 在线观看国产一区二区三区 | 日本在线高清不卡免费播放 | 国产欧美亚洲精品a | 国产在线精品一区二区三区直播 | 亚洲精品无码人妻无码 | aa片在线观看视频在线播放 | 日韩精品无码一本二本三本色 | 97久久国产亚洲精品超碰热 | 国产精华av午夜在线观看 | 国产精品久久久av久久久 | 7777奇米四色成人眼影 | 三上悠亚人妻中文字幕在线 | 精品欧洲av无码一区二区三区 | 在线精品亚洲一区二区 | 18禁止看的免费污网站 | 欧美黑人巨大xxxxx | av无码久久久久不卡免费网站 | 日本大香伊一区二区三区 | 亚洲综合无码久久精品综合 | 国精品人妻无码一区二区三区蜜柚 | 国产卡一卡二卡三 | 亚洲日韩av一区二区三区中文 | 成熟人妻av无码专区 | 成 人影片 免费观看 | 精品国产一区二区三区av 性色 | 动漫av一区二区在线观看 | 亚洲国产精品无码久久久久高潮 | 国语自产偷拍精品视频偷 | 亚洲天堂2017无码 | 国产精华av午夜在线观看 | 强伦人妻一区二区三区视频18 | 人妻aⅴ无码一区二区三区 | 国产精品亚洲综合色区韩国 | 精品国产一区二区三区四区 | 无码av免费一区二区三区试看 | 婷婷五月综合缴情在线视频 | 亚洲精品鲁一鲁一区二区三区 | 日本丰满熟妇videos | 国产乱人伦偷精品视频 | 久久久久99精品成人片 | 又大又硬又黄的免费视频 | 最新版天堂资源中文官网 | 乱码av麻豆丝袜熟女系列 | 国产精品久久久久9999小说 | 午夜精品一区二区三区在线观看 | 伊人久久大香线蕉av一区二区 | 51国偷自产一区二区三区 | 色婷婷综合激情综在线播放 | 天天拍夜夜添久久精品 | 成人性做爰aaa片免费看不忠 | 黄网在线观看免费网站 | 性色欲网站人妻丰满中文久久不卡 | 狂野欧美性猛xxxx乱大交 | 正在播放东北夫妻内射 | 国模大胆一区二区三区 | 欧美丰满少妇xxxx性 | 蜜桃av抽搐高潮一区二区 | 无码成人精品区在线观看 | 美女张开腿让人桶 | 亚洲熟妇自偷自拍另类 | 人人妻人人澡人人爽人人精品 | 久久久久久久久888 | 国产人妻精品一区二区三区 | 午夜理论片yy44880影院 | 久久久久av无码免费网 | 日日噜噜噜噜夜夜爽亚洲精品 | 亚洲一区二区三区无码久久 | 久久久久久av无码免费看大片 | 成人无码视频在线观看网站 | 日韩欧美中文字幕在线三区 | 色综合久久久无码中文字幕 | 日本大香伊一区二区三区 | 国内丰满熟女出轨videos | 亚洲精品一区二区三区在线观看 | 久久无码专区国产精品s | 亚洲精品成a人在线观看 | 男女作爱免费网站 | 熟妇女人妻丰满少妇中文字幕 | 99久久亚洲精品无码毛片 | 亚洲一区二区三区 | 野外少妇愉情中文字幕 | 狠狠色噜噜狠狠狠7777奇米 | 在线精品亚洲一区二区 | 亚洲国产av美女网站 | 乱码av麻豆丝袜熟女系列 | 欧美35页视频在线观看 | 西西人体www44rt大胆高清 | 激情五月综合色婷婷一区二区 | 欧美日本精品一区二区三区 | 色婷婷久久一区二区三区麻豆 | 67194成是人免费无码 | 天天躁日日躁狠狠躁免费麻豆 | 老司机亚洲精品影院无码 | 草草网站影院白丝内射 | 欧美老妇交乱视频在线观看 | 国产精品久久国产精品99 | 久久久精品456亚洲影院 | 国产无遮挡又黄又爽免费视频 | 狠狠色色综合网站 | 亚洲国产精品一区二区第一页 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 亚洲欧美综合区丁香五月小说 | 亚洲国产av精品一区二区蜜芽 | 又大又硬又黄的免费视频 | 精品久久久中文字幕人妻 | 人人妻人人澡人人爽精品欧美 | 97久久国产亚洲精品超碰热 | 欧美三级不卡在线观看 | 国产成人精品视频ⅴa片软件竹菊 | 国产一区二区三区影院 | 亚洲欧美日韩成人高清在线一区 | 香港三级日本三级妇三级 | 亚洲欧美国产精品久久 | 99久久无码一区人妻 | 色狠狠av一区二区三区 | 亚洲成av人在线观看网址 | 亚洲一区二区三区含羞草 | 亚洲gv猛男gv无码男同 | 亚洲色偷偷男人的天堂 | 国内老熟妇对白xxxxhd | 激情国产av做激情国产爱 | 国产精品国产自线拍免费软件 | 国产精品资源一区二区 | av人摸人人人澡人人超碰下载 | 色综合久久久久综合一本到桃花网 | 久久97精品久久久久久久不卡 | 日本熟妇人妻xxxxx人hd | 欧美成人家庭影院 | 国产性生交xxxxx无码 | 欧美性猛交内射兽交老熟妇 | 无码国模国产在线观看 | 久在线观看福利视频 | 老熟妇乱子伦牲交视频 | 三上悠亚人妻中文字幕在线 | 一个人看的www免费视频在线观看 | 久久久av男人的天堂 | 久久精品女人天堂av免费观看 | 成人免费视频视频在线观看 免费 | 亚洲日韩一区二区三区 | 欧洲欧美人成视频在线 | 国产亚洲精品久久久久久 | 亚洲国产精品久久久久久 | 亚洲爆乳精品无码一区二区三区 | 日韩少妇内射免费播放 | 中文精品久久久久人妻不卡 | 老熟妇乱子伦牲交视频 | 久久午夜无码鲁丝片 | 1000部啪啪未满十八勿入下载 | 久久久国产精品无码免费专区 | 波多野结衣一区二区三区av免费 | 中文字幕无码人妻少妇免费 | 97无码免费人妻超级碰碰夜夜 | 国产精品亚洲а∨无码播放麻豆 | a在线观看免费网站大全 | 好男人www社区 | 国产精品亚洲а∨无码播放麻豆 | 久久亚洲精品中文字幕无男同 | 久久精品人人做人人综合试看 | 国产在线aaa片一区二区99 | 精品厕所偷拍各类美女tp嘘嘘 | 狠狠躁日日躁夜夜躁2020 | 未满成年国产在线观看 | 成人av无码一区二区三区 | 色诱久久久久综合网ywww | 中文字幕无码免费久久9一区9 | 亚洲欧洲无卡二区视頻 | 我要看www免费看插插视频 | 精品无码国产自产拍在线观看蜜 | 波多野结衣aⅴ在线 | 综合激情五月综合激情五月激情1 | 中文字幕亚洲情99在线 | 狠狠色丁香久久婷婷综合五月 | 久久亚洲中文字幕无码 | 久久综合久久自在自线精品自 | 日韩少妇内射免费播放 | 影音先锋中文字幕无码 | 一本大道久久东京热无码av | 高潮毛片无遮挡高清免费视频 | 青青草原综合久久大伊人精品 | 麻豆蜜桃av蜜臀av色欲av | 久久综合香蕉国产蜜臀av | 欧美丰满熟妇xxxx性ppx人交 | 成人试看120秒体验区 | 无码人妻精品一区二区三区不卡 | 成人一在线视频日韩国产 | 国产舌乚八伦偷品w中 | 中文字幕无码热在线视频 | 无人区乱码一区二区三区 | 欧美午夜特黄aaaaaa片 | 国产后入清纯学生妹 | 日本爽爽爽爽爽爽在线观看免 | 亚洲小说春色综合另类 | 久久国产精品萌白酱免费 | 日韩 欧美 动漫 国产 制服 | 亚洲 欧美 激情 小说 另类 | 国产99久久精品一区二区 | a在线亚洲男人的天堂 | 丝袜人妻一区二区三区 | www成人国产高清内射 | 精品少妇爆乳无码av无码专区 | 日本熟妇大屁股人妻 | 久久精品中文字幕一区 | 国产乱人伦偷精品视频 | 欧美zoozzooz性欧美 | 亚洲成av人综合在线观看 | 国产精品久久久久9999小说 | 中文精品久久久久人妻不卡 | 夜夜高潮次次欢爽av女 | 天下第一社区视频www日本 | 娇妻被黑人粗大高潮白浆 | 亚洲精品成人av在线 | 蜜臀av无码人妻精品 | 欧美自拍另类欧美综合图片区 | 国产无套内射久久久国产 | 玩弄人妻少妇500系列视频 | 国产三级久久久精品麻豆三级 | 在线欧美精品一区二区三区 | 国产人妻久久精品二区三区老狼 | 成人精品一区二区三区中文字幕 | 久久精品国产精品国产精品污 | 国产办公室秘书无码精品99 | av小次郎收藏 | 3d动漫精品啪啪一区二区中 | 疯狂三人交性欧美 | 给我免费的视频在线观看 | 亚洲精品国产a久久久久久 | 亚洲国产精品无码一区二区三区 | 日本在线高清不卡免费播放 | 国产乱子伦视频在线播放 | 国产在线无码精品电影网 | 久久精品人人做人人综合试看 | 好爽又高潮了毛片免费下载 | 国产精品多人p群无码 | 国产亚洲精品久久久久久 | 久久综合狠狠综合久久综合88 | 国产av无码专区亚洲a∨毛片 | 国产三级久久久精品麻豆三级 | 人妻aⅴ无码一区二区三区 | 日本熟妇人妻xxxxx人hd | 国模大胆一区二区三区 | 午夜男女很黄的视频 | 一本大道久久东京热无码av | 国产真人无遮挡作爱免费视频 | 日韩无码专区 | 色婷婷欧美在线播放内射 | 六十路熟妇乱子伦 | 漂亮人妻洗澡被公强 日日躁 | 久久久久人妻一区精品色欧美 | 综合激情五月综合激情五月激情1 | 一本色道婷婷久久欧美 | 色妞www精品免费视频 | 老头边吃奶边弄进去呻吟 | 精品无码av一区二区三区 | 又粗又大又硬又长又爽 | 亚洲精品成a人在线观看 | 亚洲国产精品成人久久蜜臀 | 精品无码一区二区三区爱欲 | 中文字幕 人妻熟女 | 国产精品第一国产精品 | 亚洲精品国产第一综合99久久 | 亚洲精品欧美二区三区中文字幕 | 18精品久久久无码午夜福利 | 综合激情五月综合激情五月激情1 | 性欧美疯狂xxxxbbbb | 亚洲s色大片在线观看 | av无码电影一区二区三区 | 欧美人与牲动交xxxx | 亚洲国产高清在线观看视频 | 欧美精品免费观看二区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产sm调教视频在线观看 | 荫蒂添的好舒服视频囗交 | 国产性生大片免费观看性 | 一本久道久久综合狠狠爱 | 亚洲第一网站男人都懂 | 精品久久久久久亚洲精品 | 夜精品a片一区二区三区无码白浆 | 98国产精品综合一区二区三区 | 国产乱人无码伦av在线a | 国产精品二区一区二区aⅴ污介绍 | 高清国产亚洲精品自在久久 | 国产在线精品一区二区三区直播 | 国产精品香蕉在线观看 | 免费看少妇作爱视频 | 亚洲欧美日韩综合久久久 | 国产特级毛片aaaaaaa高清 | 2019午夜福利不卡片在线 | 亚洲精品成a人在线观看 | 国产午夜视频在线观看 | 欧美老妇与禽交 | 日日鲁鲁鲁夜夜爽爽狠狠 | 蜜桃视频插满18在线观看 | 女人被男人躁得好爽免费视频 | 最近中文2019字幕第二页 | 18黄暴禁片在线观看 | 午夜福利试看120秒体验区 | 色婷婷欧美在线播放内射 | 日本肉体xxxx裸交 | 国产成人一区二区三区别 | 欧美人与禽zoz0性伦交 | 55夜色66夜色国产精品视频 | aa片在线观看视频在线播放 | 亚洲狠狠婷婷综合久久 | 国产成人人人97超碰超爽8 | 国内少妇偷人精品视频 | 亚洲国产精品无码一区二区三区 | 日本高清一区免费中文视频 | 国产午夜手机精彩视频 | 亚洲国产精品无码一区二区三区 | 免费视频欧美无人区码 | аⅴ资源天堂资源库在线 | 无码一区二区三区在线观看 | 日日鲁鲁鲁夜夜爽爽狠狠 | 精品无码一区二区三区的天堂 | 婷婷五月综合激情中文字幕 | 国内揄拍国内精品人妻 | 中文字幕 亚洲精品 第1页 | 偷窥日本少妇撒尿chinese | 日本大香伊一区二区三区 | 国产亚洲美女精品久久久2020 | 国产suv精品一区二区五 | 男人和女人高潮免费网站 | 人人澡人人妻人人爽人人蜜桃 | 国产欧美亚洲精品a | 国产精品无码mv在线观看 | 日本一区二区三区免费高清 | 国产两女互慰高潮视频在线观看 | 中文字幕人妻丝袜二区 | 人妻插b视频一区二区三区 | 特级做a爰片毛片免费69 | 日本在线高清不卡免费播放 | 日韩精品无码一区二区中文字幕 | 十八禁视频网站在线观看 | 亚洲日韩av一区二区三区四区 | 精品久久久久久人妻无码中文字幕 | 狠狠cao日日穞夜夜穞av | 国产精品鲁鲁鲁 | 狠狠cao日日穞夜夜穞av | 特黄特色大片免费播放器图片 | 亚洲成av人片在线观看无码不卡 | 国产激情一区二区三区 | 99久久亚洲精品无码毛片 | 午夜免费福利小电影 | 波多野结衣av一区二区全免费观看 | 国精品人妻无码一区二区三区蜜柚 | 中文字幕av日韩精品一区二区 | 中文字幕人妻丝袜二区 | 麻豆国产人妻欲求不满谁演的 | 无码人妻丰满熟妇区毛片18 | 婷婷五月综合缴情在线视频 | 午夜精品一区二区三区的区别 | 奇米影视7777久久精品人人爽 | 欧美兽交xxxx×视频 | 色五月五月丁香亚洲综合网 | aa片在线观看视频在线播放 | 久久精品视频在线看15 | 日本www一道久久久免费榴莲 | 国产av一区二区三区最新精品 | 亚洲成a人一区二区三区 | 国产农村乱对白刺激视频 | 精品日本一区二区三区在线观看 | 色爱情人网站 | 97精品国产97久久久久久免费 | 国产午夜亚洲精品不卡 | 中文字幕无码免费久久9一区9 | 熟妇激情内射com | 极品嫩模高潮叫床 | 欧美三级不卡在线观看 | 少妇一晚三次一区二区三区 | 麻豆果冻传媒2021精品传媒一区下载 | 久久99精品国产.久久久久 | 欧美精品免费观看二区 | 欧美丰满少妇xxxx性 | 国产香蕉尹人视频在线 | 激情内射亚州一区二区三区爱妻 | 亚洲综合无码一区二区三区 | 特黄特色大片免费播放器图片 | 激情内射亚州一区二区三区爱妻 | 久久久中文久久久无码 | 国产综合色产在线精品 | 国内揄拍国内精品人妻 | 高清国产亚洲精品自在久久 | 国产内射爽爽大片视频社区在线 | 国产偷自视频区视频 | 18禁黄网站男男禁片免费观看 | av无码久久久久不卡免费网站 | 亚洲精品一区三区三区在线观看 | 亚洲码国产精品高潮在线 | 性生交大片免费看l | 国产精品无码久久av | 国产av久久久久精东av | 又黄又爽又色的视频 | 亚洲国产欧美日韩精品一区二区三区 | 国产肉丝袜在线观看 | 国产精品对白交换视频 | 亚洲热妇无码av在线播放 | 天天做天天爱天天爽综合网 | 免费视频欧美无人区码 | 色一情一乱一伦一区二区三欧美 | 国产精品99久久精品爆乳 | 亚洲男人av香蕉爽爽爽爽 | 青青草原综合久久大伊人精品 | 麻豆md0077饥渴少妇 | 精品久久久久久人妻无码中文字幕 | 国产一区二区三区精品视频 | 亚洲一区二区三区含羞草 | 99久久精品日本一区二区免费 | 嫩b人妻精品一区二区三区 | 亚洲精品www久久久 | 粉嫩少妇内射浓精videos | 亚洲小说春色综合另类 | 国产精品免费大片 | 久久久久人妻一区精品色欧美 | 国产无套粉嫩白浆在线 | 久久精品国产99久久6动漫 | 国产亚洲精品久久久闺蜜 | 四虎影视成人永久免费观看视频 | 好屌草这里只有精品 | 亚洲一区二区三区偷拍女厕 | 男人的天堂av网站 | 国产人妻久久精品二区三区老狼 | 中文字幕无码av激情不卡 | 男人和女人高潮免费网站 | 一二三四在线观看免费视频 | 日韩精品无码免费一区二区三区 | 国产内射爽爽大片视频社区在线 | 99精品国产综合久久久久五月天 | 在教室伦流澡到高潮hnp视频 | 无套内谢老熟女 | 成在人线av无码免观看麻豆 | 扒开双腿疯狂进出爽爽爽视频 | 久久精品国产一区二区三区 | 亚洲精品成人av在线 | 任你躁国产自任一区二区三区 | 麻豆国产人妻欲求不满谁演的 | 欧洲vodafone精品性 | 亚洲春色在线视频 | 久久无码中文字幕免费影院蜜桃 | 日本www一道久久久免费榴莲 | 色欲久久久天天天综合网精品 | 久久久久成人片免费观看蜜芽 | 亚洲中文字幕在线无码一区二区 | 性欧美videos高清精品 | 搡女人真爽免费视频大全 | 双乳奶水饱满少妇呻吟 | 搡女人真爽免费视频大全 | 亚洲乱码中文字幕在线 | 欧美日本免费一区二区三区 | 国产精品亚洲а∨无码播放麻豆 | 国产97在线 | 亚洲 | 樱花草在线播放免费中文 | 国产亚洲精品精品国产亚洲综合 | 国产av久久久久精东av | 98国产精品综合一区二区三区 | 日本护士xxxxhd少妇 | 好男人社区资源 | 国产网红无码精品视频 | 少妇愉情理伦片bd | 国产农村妇女高潮大叫 | 97夜夜澡人人双人人人喊 | 日产精品高潮呻吟av久久 | 少妇人妻大乳在线视频 | 色综合久久久久综合一本到桃花网 | 97精品人妻一区二区三区香蕉 | 久久久久久av无码免费看大片 | 日日天干夜夜狠狠爱 | 久久天天躁夜夜躁狠狠 | 欧美日韩久久久精品a片 | 午夜精品久久久久久久 | 最新国产麻豆aⅴ精品无码 | 一个人免费观看的www视频 | 亚洲精品无码国产 | 亚洲一区二区三区播放 | 日本熟妇乱子伦xxxx | 久久综合激激的五月天 | 玩弄少妇高潮ⅹxxxyw | 性做久久久久久久久 | 色五月五月丁香亚洲综合网 | 亚洲无人区一区二区三区 | 久久久中文久久久无码 | 精品亚洲韩国一区二区三区 | 日本高清一区免费中文视频 | 99riav国产精品视频 | 免费观看又污又黄的网站 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲色偷偷偷综合网 | 欧美性生交xxxxx久久久 | 装睡被陌生人摸出水好爽 | 欧美日本日韩 | 日韩在线不卡免费视频一区 | 久久精品人人做人人综合 | 国产97在线 | 亚洲 | 精品久久综合1区2区3区激情 | 日日摸天天摸爽爽狠狠97 | 欧美freesex黑人又粗又大 | 久久人人97超碰a片精品 | 荡女精品导航 | 97久久国产亚洲精品超碰热 | 免费观看的无遮挡av | 成人欧美一区二区三区黑人免费 | 国产无套粉嫩白浆在线 | 亚洲 a v无 码免 费 成 人 a v | 乱码av麻豆丝袜熟女系列 | 欧美日韩人成综合在线播放 | 亚洲男人av香蕉爽爽爽爽 | 欧美自拍另类欧美综合图片区 | 女人被男人躁得好爽免费视频 | 亚洲の无码国产の无码影院 | 中文字幕乱妇无码av在线 | 搡女人真爽免费视频大全 | 色噜噜亚洲男人的天堂 | 中文字幕亚洲情99在线 | 日本丰满护士爆乳xxxx | 人人妻人人澡人人爽人人精品 | 色综合视频一区二区三区 | 国产xxx69麻豆国语对白 | 桃花色综合影院 | 国产成人av免费观看 | 亚洲精品综合一区二区三区在线 | 欧美日韩一区二区免费视频 | 久久国内精品自在自线 | 国产成人av免费观看 | 给我免费的视频在线观看 | 天天av天天av天天透 | 精品国精品国产自在久国产87 | 亚洲а∨天堂久久精品2021 | 亚洲精品午夜无码电影网 | 欧洲vodafone精品性 | 丝袜美腿亚洲一区二区 | 亚洲一区av无码专区在线观看 | 97久久精品无码一区二区 | 国产亚av手机在线观看 | 亚洲熟悉妇女xxx妇女av | 女人被爽到呻吟gif动态图视看 | 亚洲成av人在线观看网址 | 日本一区二区三区免费播放 | 无码人妻少妇伦在线电影 | 亚洲经典千人经典日产 | 一本大道伊人av久久综合 | 丝袜 中出 制服 人妻 美腿 | 又紧又大又爽精品一区二区 | 女人被男人爽到呻吟的视频 | 国产人妻精品一区二区三区不卡 | 中文字幕乱码人妻无码久久 | 亚洲 高清 成人 动漫 | 强奷人妻日本中文字幕 | 欧美熟妇另类久久久久久多毛 | 久在线观看福利视频 | 伊人久久大香线蕉午夜 | 色综合久久久无码网中文 | 久久久亚洲欧洲日产国码αv | 国产精品亚洲综合色区韩国 | 欧美精品无码一区二区三区 | 黄网在线观看免费网站 | 少妇无码吹潮 | 国产在线一区二区三区四区五区 | 久久精品国产99精品亚洲 | 窝窝午夜理论片影院 | aⅴ在线视频男人的天堂 | 久久 国产 尿 小便 嘘嘘 | 久久精品中文闷骚内射 | 熟妇人妻无码xxx视频 | 无码一区二区三区在线 | 日日橹狠狠爱欧美视频 | 欧美一区二区三区视频在线观看 | 乱中年女人伦av三区 | 国产高清av在线播放 | 成 人影片 免费观看 | 午夜理论片yy44880影院 | 永久黄网站色视频免费直播 | 99久久婷婷国产综合精品青草免费 | av香港经典三级级 在线 | 人妻少妇被猛烈进入中文字幕 | 天堂久久天堂av色综合 | 亚洲热妇无码av在线播放 | 久9re热视频这里只有精品 | 无码任你躁久久久久久久 | 曰韩少妇内射免费播放 | 乌克兰少妇xxxx做受 | 99久久人妻精品免费一区 | 无套内谢的新婚少妇国语播放 | 国产综合在线观看 | 亚洲娇小与黑人巨大交 | 激情人妻另类人妻伦 | 无遮挡啪啪摇乳动态图 | 日韩欧美中文字幕公布 | 久久精品一区二区三区四区 | 精品无码国产一区二区三区av | 午夜免费福利小电影 | 欧美老熟妇乱xxxxx | 无码免费一区二区三区 | 黑人巨大精品欧美黑寡妇 | 日本熟妇人妻xxxxx人hd | 爽爽影院免费观看 | 丰满岳乱妇在线观看中字无码 | 精品欧美一区二区三区久久久 | 色一情一乱一伦一区二区三欧美 | 国产精品自产拍在线观看 | 成人无码精品一区二区三区 | 久久这里只有精品视频9 | 亚洲中文字幕在线无码一区二区 | 久久久精品国产sm最大网站 | 欧美肥老太牲交大战 | 日韩精品a片一区二区三区妖精 | 少妇无码一区二区二三区 | 欧美性生交xxxxx久久久 | 国产精品人人妻人人爽 | 东京无码熟妇人妻av在线网址 | 蜜桃视频插满18在线观看 | 国产精品怡红院永久免费 | 无码一区二区三区在线观看 | 荡女精品导航 | 又大又硬又黄的免费视频 | 亚洲成av人影院在线观看 | 玩弄人妻少妇500系列视频 | 国产亚洲人成在线播放 | 日韩av激情在线观看 | 天天拍夜夜添久久精品 | 色综合久久久无码中文字幕 | 日本精品久久久久中文字幕 | 99精品国产综合久久久久五月天 | 人妻天天爽夜夜爽一区二区 | 乱码av麻豆丝袜熟女系列 | www国产亚洲精品久久久日本 | 蜜臀aⅴ国产精品久久久国产老师 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产激情无码一区二区app | 人妻中文无码久热丝袜 | 亚洲中文字幕va福利 | 日韩精品久久久肉伦网站 | 国产欧美精品一区二区三区 | 久久国语露脸国产精品电影 | 欧美freesex黑人又粗又大 | 久久无码中文字幕免费影院蜜桃 | 国产熟妇高潮叫床视频播放 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲国产精品成人久久蜜臀 | 国内揄拍国内精品少妇国语 | 永久免费观看美女裸体的网站 | 午夜无码区在线观看 | 丝袜美腿亚洲一区二区 | 少妇人妻偷人精品无码视频 | 日本精品少妇一区二区三区 | 国产精品久久久久久久9999 | 一本一道久久综合久久 | 久久综合色之久久综合 | 国产成人久久精品流白浆 | 中文无码伦av中文字幕 | 人妻少妇精品视频专区 | 麻豆国产丝袜白领秘书在线观看 | 无码精品人妻一区二区三区av | 麻豆果冻传媒2021精品传媒一区下载 | 国产在线精品一区二区高清不卡 | 日产国产精品亚洲系列 | 国产内射爽爽大片视频社区在线 | 成人欧美一区二区三区黑人 | 国产成人精品久久亚洲高清不卡 | 人妻人人添人妻人人爱 | 啦啦啦www在线观看免费视频 | 亚洲色偷偷偷综合网 | 亚洲gv猛男gv无码男同 | 国产免费久久精品国产传媒 | 日韩av无码一区二区三区不卡 | 永久免费精品精品永久-夜色 | 亚洲国产成人a精品不卡在线 | 亚洲热妇无码av在线播放 | 亚洲国产欧美日韩精品一区二区三区 | 亚洲中文字幕成人无码 | 国产成人av免费观看 | 国产成人无码区免费内射一片色欲 | 久久国产精品_国产精品 | 少妇高潮喷潮久久久影院 | 欧美成人免费全部网站 | 欧美 日韩 人妻 高清 中文 | 婷婷综合久久中文字幕蜜桃三电影 | 熟女体下毛毛黑森林 | 成年美女黄网站色大免费视频 | 国产香蕉尹人视频在线 | 欧美35页视频在线观看 | 两性色午夜免费视频 | 欧美丰满老熟妇xxxxx性 | 特黄特色大片免费播放器图片 | 色综合久久中文娱乐网 | 中文字幕色婷婷在线视频 | 国产午夜手机精彩视频 | 全球成人中文在线 | 亚洲中文字幕在线无码一区二区 | 国产99久久精品一区二区 | 欧美精品无码一区二区三区 | 亚洲大尺度无码无码专区 | 午夜丰满少妇性开放视频 | 国产乱人伦偷精品视频 | 男人和女人高潮免费网站 | 亚洲区欧美区综合区自拍区 | 宝宝好涨水快流出来免费视频 | 国产精品鲁鲁鲁 | 人人妻人人澡人人爽精品欧美 | 国产一精品一av一免费 | 18禁黄网站男男禁片免费观看 | 成年美女黄网站色大免费视频 | 亚洲熟悉妇女xxx妇女av | 成人精品一区二区三区中文字幕 | 欧洲极品少妇 | 蜜桃臀无码内射一区二区三区 | 色综合天天综合狠狠爱 | 国产亚洲人成在线播放 | 性欧美videos高清精品 | 欧美亚洲国产一区二区三区 | 亚洲精品一区二区三区婷婷月 | 国模大胆一区二区三区 | 国产一区二区三区精品视频 | 国产精品自产拍在线观看 | 人妻少妇被猛烈进入中文字幕 | 麻豆国产97在线 | 欧洲 | 激情五月综合色婷婷一区二区 | 欧美变态另类xxxx | 4hu四虎永久在线观看 | 国产亚洲美女精品久久久2020 | 欧美三级a做爰在线观看 | 少妇久久久久久人妻无码 | 成熟妇人a片免费看网站 | 成人免费视频在线观看 | 77777熟女视频在线观看 а天堂中文在线官网 | 7777奇米四色成人眼影 | 水蜜桃色314在线观看 | www国产亚洲精品久久久日本 | 亚洲自偷自偷在线制服 | 国产乡下妇女做爰 | 福利一区二区三区视频在线观看 | 亚洲国产av美女网站 | 亚洲国产成人a精品不卡在线 | 亚洲毛片av日韩av无码 | 亚洲精品一区二区三区四区五区 | 久久熟妇人妻午夜寂寞影院 | 欧美日韩综合一区二区三区 | 九一九色国产 | 粉嫩少妇内射浓精videos | 国产午夜福利100集发布 | 大乳丰满人妻中文字幕日本 | 亚洲中文字幕无码中字 | 国产亚洲精品久久久久久 | 四十如虎的丰满熟妇啪啪 | 国产农村乱对白刺激视频 | 精品无码国产自产拍在线观看蜜 | 国产一精品一av一免费 | 风流少妇按摩来高潮 | 无码国内精品人妻少妇 | 色婷婷欧美在线播放内射 | 鲁鲁鲁爽爽爽在线视频观看 | 国产三级久久久精品麻豆三级 | 久久国产精品精品国产色婷婷 | 丝袜 中出 制服 人妻 美腿 | 内射后入在线观看一区 | 国产精品久久久久久久影院 | 女人被男人躁得好爽免费视频 | 东北女人啪啪对白 | 日韩亚洲欧美精品综合 | 99久久久无码国产精品免费 | 国产午夜无码精品免费看 | 在线播放无码字幕亚洲 | 99久久人妻精品免费一区 | 内射欧美老妇wbb | 国产性生交xxxxx无码 | 亚洲成在人网站无码天堂 | 一区二区三区乱码在线 | 欧洲 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲中文无码av永久不收费 | 老子影院午夜伦不卡 | 无套内谢的新婚少妇国语播放 | 欧美人与牲动交xxxx | 狠狠色噜噜狠狠狠狠7777米奇 | 国内少妇偷人精品视频免费 | 国产黄在线观看免费观看不卡 | 人人妻人人澡人人爽精品欧美 | 麻豆精品国产精华精华液好用吗 | 国产人妻久久精品二区三区老狼 | 一本一道久久综合久久 | 久久久国产精品无码免费专区 | 精品aⅴ一区二区三区 | 免费国产黄网站在线观看 | 久久综合久久自在自线精品自 | 久久国产精品二国产精品 | 老子影院午夜伦不卡 | 国产av一区二区精品久久凹凸 | 亚洲色大成网站www | 国产美女极度色诱视频www | 久久精品国产一区二区三区 | 丰满人妻精品国产99aⅴ | 午夜精品久久久久久久久 | 欧美日韩一区二区免费视频 | 初尝人妻少妇中文字幕 | 久久国产36精品色熟妇 | 亚洲国产精品无码久久久久高潮 | 亚洲熟妇色xxxxx欧美老妇 | 东京热一精品无码av | 亚洲人成影院在线观看 | 丰满人妻精品国产99aⅴ | 十八禁真人啪啪免费网站 | 丝袜美腿亚洲一区二区 | 亚洲精品中文字幕久久久久 | 麻豆精品国产精华精华液好用吗 | 国产97在线 | 亚洲 | 少妇高潮一区二区三区99 | 欧美肥老太牲交大战 | 国产精品国产三级国产专播 | 国产精品二区一区二区aⅴ污介绍 | 女人被爽到呻吟gif动态图视看 | 久久精品中文字幕一区 | 国产精品人人妻人人爽 | 国产性生大片免费观看性 | 亚洲国产成人a精品不卡在线 | 欧美熟妇另类久久久久久不卡 | 午夜精品久久久久久久 | 色欲久久久天天天综合网精品 | 中文字幕无码热在线视频 | 久久久久久国产精品无码下载 | 中文字幕+乱码+中文字幕一区 | 内射巨臀欧美在线视频 | 国内精品人妻无码久久久影院蜜桃 | 日本丰满护士爆乳xxxx |