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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

从达标到卓越 —— API 设计之道

發布時間:2024/8/23 编程问答 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 从达标到卓越 —— API 设计之道 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

摘要: 新技術層出不窮,長江后浪推前浪。在浪潮褪去后,能留下來的,是一些經典的設計思想。 在前端界,以前有遠近聞名的 jQuery,近來有聲名鵲起的 Vue.js。這兩者叫好又叫座的原因固然有很多,但是其中有一個共同特質不可忽視,那便是它們的 API 設計 非常優雅。 因此這次我想來談個大課題 —— API 設計之道。 ******

新技術層出不窮,長江后浪推前浪。在浪潮褪去后,能留下來的,是一些經典的設計思想。

在前端界,以前有遠近聞名的 jQuery,近來有聲名鵲起的 Vue.js。這兩者叫好又叫座的原因固然有很多,但是其中有一個共同特質不可忽視,那便是它們的 API 設計 非常優雅。

因此這次我想來談個大課題 —— API 設計之道。

討論內容的定義域
本文并不是《jQuery API 賞析》,當我們談論 API 的設計時,不只局限于討論「某個框架應該如何設計暴露出來的方法」。作為程序世界分治復雜邏輯的基本協作手段,廣義的 API 設計涉及到我們日常開發中的方方面面。

最常見的 API 暴露途徑是函數聲明(Function Signature),以及屬性字段(Attributes);而當我們涉及到前后端 IO 時,則需要關注通信接口的數據結構(JSON Schema);如果還有異步的通信,那么事件(Events)或消息(Message)如何設計也是個問題;甚至,依賴一個包(Package)的時候,包名本身就是接口,你是否也曾碰到過一個奇葩的包名而吐槽半天?

總之,「API 設計」不只關乎到框架或庫的設計者,它和每個開發者息息相關。

提綱挈領
有一個核心問題是,我們如何評判一個 API 的設計算「好」?在我看來,一言以蔽之,易用。

那「易用」又是什么呢?我的理解是,只要能夠足夠接近人類的日常語言和思維,并且不需要引發額外的大腦思考,那就是易用。

Don’t make me think.
具體地,我根據這些年來碰到的大量(反面和正面)案例,歸納出以下這些要點。按照要求從低到高的順序如下:

達標:詞法和語法
正確拼寫
準確用詞
注意單復數
不要搞錯詞性
處理縮寫
用對時態和語態
進階:語義和可用性
單一職責
避免副作用
合理設計函數參數
合理運用函數重載
使返回值可預期
固化術語表
遵循一致的 API 風格
卓越:系統性和大局觀
版本控制
確保向下兼容
設計擴展機制
控制 API 的抽象級別
收斂 API 集
發散 API 集
制定 API 的支持策略
(本文主要以 JavaScript 作為語言示例。)

達標:詞法和語法
高級語言和自然語言(英語)其實相差無幾,因此正確地使用(英語的)詞法和語法是程序員最基本的素養。而涉及到 API 這種供用戶調用的代碼時,則尤其重要。

但事實上,由于亞洲地區對英語的掌握能力普遍一般……所以現實狀況并不樂觀 —— 如果以正確使用詞法和語法作為達標的門檻,很多 API 都沒能達標。

正確拼寫
正確地拼寫一個單詞是底線,這一點無需贅述。然而 API 中的各種錯別字現象仍屢見不鮮,即使是在我們阿里這樣的大公司內。

曾經有某個 JSON 接口(mtop)返回這樣一組店鋪數據,以在前端模板中渲染:

// json
[
{
“shopBottom”: {
“isTmall”: “false”,
“shopLevel”: “916”,
“shopLeveImg”: “//xxx.jpg”
}
}
]
乍一看平淡無奇,結果我調試了小半天都沒能渲染出店鋪的「店鋪等級標識圖片」,即 shopLevelImg 字段。問題到底出在了哪里?

眼細的朋友可能已經發現,接口給的字段名是 shopLeveImg,少了一個 l,而在其后字母 I 的光輝照耀下,肉眼很難分辨出這個細節問題。

拼錯單詞的問題真的是太普遍了,再比如:

某個叫做 toast 的庫,package.json 中的 name 寫成了 taost。導致在 npm 中沒能找到這個包。
某個跑馬燈組件,工廠方法中的一個屬性錯將 panel 寫成了 pannel。導致以正確的屬性名初始化時代碼跑不起來。
某個 url(www.ruanyifeng.com/blog/2017/01/entainment.html)中錯將 entertainment 寫成了 entainment……這倒沒什么大影響,只是 url 發布后就改不了了,留下了錯別字不好看。
……
注意到,這些拼寫錯誤經常出現在 字符串 的場景中。不同于變量名,IDE 無法檢查字符串中的單詞是否科學、是否和一些變量名一致,因此,我們在對待一些需要公開出去的 API 時,需要尤其注意這方面的問題;另一方面,更認真地注意 IDE 的 typo 提示(單詞拼寫錯誤提示),也會對我們產生很大幫助。

準確用詞
我們知道,中英文單詞的含義并非一一對應,有時一個中文意思可以用不同的英文單詞來解釋,這時我們需要選擇使用恰當的準確的詞來描述。

比如中文的「消息」可以翻譯為 message、notification、news 等。雖然這幾個不同的單詞都可以有「消息」的意思,但它們在用法和語境場景上存在著細微差異:

message:一般指雙方通信的消息,是內容載體。而且經常有來有往、成對出現。比如 postMessage() 和 receiveMessage()。
notification:經常用于那種比較短小的通知,現在甚至專指 iOS / Android 那樣的通知消息。比如 new NotificationManager()。
news:內容較長的新聞消息,比 notification 更重量級。比如 getTopNews()。
feed:自從 RSS 訂閱時代出現的一個單詞,現在 RSS 已經日薄西山,但是 feed 這個詞被用在了更多的地方。其含義只可意會不可言傳。比如 fetchWeitaoFeeds()。
所以,即使中文意思大體相近,也要準確地用詞,從而讓讀者更易理解 API 的作用和 上下文場景。

有一個正面案例,是關于 React 的。(在未使用 ES2015 的)React 中,有兩個方法叫做:

React.createClass({
getDefaultProps: function() {
// return a dictionary
},
getInitialState: function() {
// return a dictionary either
}
});
它們的作用都是用來定義初始化的組件信息,返回值的類型也都一樣,但是在方法名上卻分別用了 default 和 initial 來修飾,為什么不統一為一個呢?

原因和 React 的機制有關:

props 是指 Element 的屬性,要么是不存在某個屬性值后來為它賦值,要么是存在屬性的默認值后來將其覆蓋。所以這種行為,default 是合理的修飾詞。
state 是整個 Component 狀態機中的某一個特定狀態,既然描述為了狀態機,那么狀態和狀態之間是互相切換的關系。所以對于初始狀態,用 initial 來修飾。
就這么個小小的細節,就可一瞥 React 本身的機制,足以體現 API 設計者的智慧。

另外,最近我還碰到了這樣一組事件 API:

// event name 1
page.emit(‘pageShowModal’);

// event name 2
page.emit(‘pageCloseModal’);
這兩個事件顯然是一對正反義的動作,在上述案例中,表示「顯示窗口」時使用了 show,表示「關閉窗口」時使用了 close,這都是非常直覺化的直譯。而事實上,成對出現的詞應該是:show & hide、open & close。

因此這里必須強調:成對出現的正反義詞不可混用。在程序世界經常成對出現的詞還有:

in & out
on & off
previous & next
forward & backward
success & failure

總之,我們可以試著擴充英語的詞匯量,使用合適的詞,這對我們準確描述 API 有很大的幫助。

注意單復數
所有涉及到諸如數組(Array)、集合(Collection)、列表(List)這樣的數據結構,在命名時都要使用復數形式:

var shopItems = [
// …
];

export function getShopItems() {
// return an array
}

// fail
export function getShopItem() {
// unless you really return a non-array
}
現實往往出人意表地糟糕,前不久剛改一個項目,我就碰到了這樣的寫法:

class MarketFloor extends Component {
state = {
item: [
{}
]
};
}
這里的 item 實為一個數組,即使它內部只有一個成員。因此應該命名為 items 或 itemList,無論如何,不應該是表示單數的 item。

同時要注意,在復數的風格上保持一致,要么所有都是 -s,要么所有都是 -list。

反過來,我們在涉及到諸如字典(Dictionary)、表(Map)的時候,不要使用復數!

// fail
var EVENT_MAPS = {
MODAL_WILL_SHOW: ‘modalWillShow’,
MODAL_WILL_HIDE: ‘modalWillHide’,
// …
};
雖然這個數據結構看上去由很多 key-value 對組成,是個類似于集合的存在,但是「map」本身已經包含了這層意思,不需要再用復數去修飾它。

不要搞錯詞性
另外一個容易犯的低級錯誤是搞錯詞性,即命名時拎不清名詞、動詞、形容詞……

asyncFunc({
success: function() {},
fail: function() {}
});
success 算是一個在程序界出鏡率很高的詞了,但是有些同學會搞混,把它當做動詞來用。在上述案例中,成對出現的單詞其詞性應該保持一致,這里應該寫作 succeed 和 fail;當然,在這個語境中,最好遵從慣例,使用名詞組合 success 和 failure。

這一對詞全部的詞性如下:

n. 名詞:success, failure
v. 動詞:succeed, fail
adj. 形容詞:successful, failed(無形容詞,以過去分詞充當)
adv. 副詞:successfully, fail to do sth.(無副詞,以不定式充當)
注意到,如果有些詞沒有對應的詞性,則考慮變通地采用其他形式來達到同樣的意思。

所以,即使我們大部分人都知道:方法命名用動詞、屬性命名用名詞、布爾值類型用形容詞(或等價的表語),但由于對某些單詞的詞性不熟悉,也會導致最終的 API 命名有問題,這樣的話就很尷尬了。

處理縮寫
關于詞法最后一個要注意的點是縮寫。有時我們經常會糾結,首字母縮寫詞(acronym)如 DOM、SQL 是用大寫還是小寫,還是僅首字母大寫,在駝峰格式中又該怎么辦……

對于這個問題,簡單不易混淆的做法是,首字母縮寫詞的所有字母均大寫。(如果某個語言環境有明確的業界慣例,則遵循慣例。)

// before
export function getDomNode() {}

// after
export function getDOMNode() {}
在經典前端庫 KISSY 的早期版本中,DOM 在 API 中都命名為 dom,駝峰下變為 Dom;而在后面的版本內統一寫定為全大寫的 DOM。

另外一種縮寫的情況是對長單詞簡寫(shortened word),如 btn (button)、chk (checkbox)、tpl (template)。這要視具體的語言規范 / 開發框架規范而定。如果什么都沒定,也沒業界慣例,那么把單詞寫全了總是不會錯的。

用對時態和語態
由于我們在調用 API 時一般類似于「調用一條指令」,所以在語法上,一個函數命名是祈使句式,時態使用一般現在時。

但在某些情況下,我們需要使用其他時態(進行時、過去時、將來時)。比如,當我們涉及到 生命周期、事件節點。

在一些組件系統中,必然涉及到生命周期,我們來看一下 React 的 API 是怎么設計的:

export function componentWillMount() {}
export function componentDidMount() {}
export function componentWillUpdate() {}
export function componentDidUpdate() {}
export function componentWillUnmount() {}
React 劃分了幾個關鍵的生命周期節點(mount, update, unmount, …),以將來時和過去時描述這些節點片段,暴露 API。注意到一個小細節,React 采用了 componentDidMount 這種過去時風格,而沒有使用 componentMounted,從而跟 componentWillMount 形成對照組,方便記憶。

同樣地,當我們設計事件 API 時,也要考慮使用合適的時態,特別是希望提供精細的事件切面時。或者,引入 before、after 這樣的介詞來簡化:

// will render
Component.on(‘beforeRender’, function() {});

// now rendering
Component.on(‘rendering’, function() {});

// has rendered
Component.on(‘afterRender’, function() {});
另一方面是關于語態,即選用主動語態和被動語態的問題。其實最好的原則就是 盡量避免使用被動語態。因為被動語態看起來會比較繞,不夠直觀,因此我們要將被動語態的 API 轉換為主動語態。

寫成代碼即形如:

// passive voice, make me confused
object.beDoneSomethingBy(subject);

// active voice, much more clear now
subject.doSomething(object);
進階:語義和可用性
說了那么多詞法和語法的注意點,不過才是達標級別而已。確保 API 的可用性和語義才使 API 真正「可用」。

無論是友好的參數設置,還是讓人甜蜜蜜的語法糖,都體現了程序員的人文關懷。

單一職責
單一職責是軟件工程中一條著名的原則,然而知易行難,一是我們對于具體業務邏輯中「職責」的劃分可能存在難度,二是部分同學仍沒有養成貫徹此原則的習慣。

小到函數級別的 API,大到整個包,保持單一核心的職責都是很重要的一件事。

// fail
component.fetchDataAndRender(url, template);

// good
var data = component.fetchData(url);
component.render(data, template);
如上,將混雜在一個大坨函數中的兩件獨立事情拆分出去,保證函數(function)級別的職責單一。

更進一步地,(假設)fetchData 本身更適合用另一個類(class)來封裝,則對原來的組件類 Component 再進行拆分,將不屬于它的取數據職責也分離出去:

class DataManager {
fetchData(url) {}
}

class Component {
constructor() {
this.dataManager = new DataManager();
}
render(data, template) {}
}

// more code, less responsibility
var data = component.dataManager.fetchData(url);
component.render(data, template);
在文件(file)層面同樣如此,一個文件只編寫一個類,保證文件的職責單一(當然這對很多語言來說是天然的規則)。

最后,視具體的業務關聯度而決定,是否將一簇文件做成一個包(package),或是拆成多個。

避免副作用
嚴格「無 副作用 的編程」幾乎只出現在純函數式程序中,現實中的 OOP 編程場景難免觸及副作用。因此在這里所說的「避免副作用」主要指的是:

函數本身的運行穩定可預期。
函數的運行不對外部環境造成意料外的污染。
對于無副作用的純函數而言,輸入同樣的參數,執行后總能得到同樣的結果,這種冪等性使得一個函數無論在什么上下文中運行、運行多少次,最后的結果總是可預期的 —— 這讓用戶非常放心,不用關心函數邏輯的細節、考慮是否應該在某個特定的時機調用、記錄調用的次數等等。希望我們以后設計的 API 不會出現這個案例中的情況:

// return x.x.x.1 while call it once
this.context.getSPM();

// return x.x.x.2 while call it twice
this.context.getSPM();
在這里,getSPM() 用來獲取每個鏈接唯一的 SPM 碼(SPM 是阿里通用的埋點統計方案)。但是用法卻顯得詭異:每調用一次,就會返回一個不同的 SPM 串,于是當我們需要獲得幾個 SPM 時,就會這樣寫:

var spm1 = this.context.getSPM();
var spm2 = this.context.getSPM();
var spm3 = this.context.getSPM();
雖然在實現上可以理解 —— 此函數內部維護了一個計數器,每次返回一個自增的 SPM D 位,但是 這樣的實現方式與這個命名看似是冪等的 getter 型函數完全不匹配,換句話說,這使得這個 API 不可預期。

如何修改之?一種做法是,不改變此函數內部的實現,而是將 API 改為 Generator 式的風格,通過形如 SPMGenerator.next() 接口來獲取自增的 SPM 碼。

另一種做法是,如果要保留原名稱,可以將函數簽名改為 getSPM(spmD),接受一個自定義的 SPM D 位,然后返回整個 SPM 碼。這樣在調用時也會更明確。

除了函數內部的運行需可預期外,它對外部一旦造成不可預期的污染,那么影響將更大,而且更隱蔽。

對外部造成污染一般是兩種途徑:一是在函數體內部直接修改外部作用域的變量,甚至全局變量;二是通過修改實參間接影響到外部環境,如果實參是引用類型的數據結構。

曾經也有發生因為對全局變量操作而導致整個容器垮掉的情況,這里就不再展開。

如何防止此類副作用發生?本質上說,需要控制讀寫權限。比如:

模塊沙箱機制,嚴格限定模塊對外部作用域的修改;
對關鍵成員作訪問控制(access control),凍結寫權限等等。
合理設計函數參數
對一個函數來說,「函數簽名」(Function Signature)比函數體本身更重要。函數名、參數設置、返回值類型,這三要素構成了完整的函數簽名。而其中,參數設置對用戶來說是接觸最頻繁,也最為關心的部分。

那如何優雅地設計函數的入口參數呢?我的理解是這樣幾個要點:

優化參數順序。相關性越高的參數越要前置。

這很好理解,相關性越高的參數越重要,越要在前面出現。其實這還有兩個隱含的意思,即 可省略的參數后置,以及 為可省略的參數設定缺省值。對某些語言來說(如 C++),調用的時候如果想省略實參,那么一定要為它定義缺省值,而帶缺省值的參數必須后置,這是在編譯層面就規定死的。而對另一部分靈活的語言來說(如 JS),將可省參數后置同樣是最佳實踐。

// bad
function renderPage(pageIndex, pageData) {}

renderPage(0, {});
renderPage(1, {});

// good
function renderPage(pageData, pageIndex = 0) {}

renderPage({});
renderPage({}, 1);
第二個要點是控制參數個數。用戶記不住過多的入口參數,因此,參數能省略則省略,或更進一步,合并同類型的參數。

由于可以方便地創建 Object 這種復合數據結構,合并參數的這種做法在 JS 中尤為普遍。常見的情況是將很多配置項都包成一個配置對象:

// traditional
$.ajax(url, params, success);

// or
$.ajax({
url,
params,
success,
failure
});
這樣做的好處是:

用戶雖然仍需記住參數名,但不用再關心參數順序。
不必擔心參數列表過長。將參數合并為字典這種結構后,想增加多少參數都可以,也不用關心需要將哪些可省略的參數后置的問題。
當然,凡事有利有弊,由于缺乏順序,就無法突出哪些是最核心的參數信息;另外,在設定參數的默認值上,會比參數列表的形式更繁瑣。因此,需要兼顧地使用最優的辦法來設計函數參數,為了同一個目的:易用。

合理運用函數重載
談到 API 的設計,尤其是函數的設計,總離不開一個機制:重載(overload)。

對于強類型語言來說,重載是個很 cool 的功能,能夠大幅減少函數名的數量,避免命名空間的污染。然而對于弱類型語言而言,由于不需要在編譯時做 type-binding,函數在調用階段想怎么傳實參都行……所以重載在這里變得非常微妙。以下著重談一下,什么時候該選擇重載,什么時候又不該。

Element getElementById(String: id)

HTMLCollection getElementsByClassName(String: names)

HTMLCollection getElementsByTagName(String: name)
以上三個函數是再經典不過的 DOM API,而在當初學習它們的時候(從 Java 思維轉到 JS 思維)我就在想這兩個問題:

為什么要設計成 getSomethingBySomething 這么復雜結構的名字,而不是使用 getSomething 做重載?
這三個函數只有 getElementById 是單數形式,為何不設計為返回 HTMLCollection(即使只返回一個成員也可以包一個 Collection 嘛),以做成復數形式的函數名從而保持一致性?
兩個問題中,如果第二個問題能解決,那么這三個函數的結構將完全一致,從而可以考慮解決第一個問題。

先來看問題二。稍微深入下 DOM 知識后就知道,id 對于整個 DOM 來說必須是唯一的,因此在理論上 getElementsById(注意有復數)將永遠返回僅有 0 或 1 個成員的 Collection,這樣一來用戶的調用方式將始終是 var element = getElementsById(id)[0],而這是非常荒謬的。所以 DOM API 設計得沒問題。

既然問題二無解,那么自然這三個函數沒法做成一個重載。退一步說,即使問題二能解決,還存在另外一個麻煩:它們的入口參數都是一樣的,都是 String!對于強類型語言來說,參數類型和順序、返回值統統一樣的情況下,壓根無法重載。因為編譯器無法通過任何一個有效的特征,來執行不同的邏輯!

所以,如果入口參數無法進行有效區分,不要選擇重載。

當然,有一種奇怪的做法可以繞過去:

// fail
function getElementsBy(byWhat, name) {
switch(byWhat) {
case ‘className’:
// …
case ‘tagName’:
// …
}
}

getElementsBy(‘tagName’, name);
getElementsBy(‘className’, name);
一種在風格上類似重載的,但實際是在運行時走分支邏輯的做法……可以看到,API 的信息總量并沒降低。不過話不能說死,這種風格在某些特定場景也有用武之地,只是多數情況下并不推薦。

與上述風格類似的,是這樣一種做法:

// get elements by tag-name by default
HTMLCollection getElements(String: name)

// if you add a flag, it goes by class-name
HTMLCollection getElements(String: name, Boolean: byClassName)
「將 flag 標記位作為了重載手段」—— 在早期微軟的一些 API 中經常能見到這樣的寫法,可以說一旦離開了文檔就無法編碼,根本不明白某個 Boolean 標記位是用來干嘛的,這大大降低了用戶的開發體驗,以及代碼可讀性。

這樣看起來,可重載的場景真是太少了!也不盡然,在我看來有一種場景很適合用重載:批量處理。

Module handleModules(Module: module)

Collection handleModules(Collection: modules)
當用戶經常面臨處理一個或多個不確定數量的對象時,他可能需要思考和判斷,什么時候用單數 handleModule、什么時候用復數 handleModules。將這種類型的操作重載為一個(大抵見于 setter 型操作),同時支持單個和批量的處理,可以降低用戶的認知負擔。

所以,在合適的時機重載,否則寧愿選擇「函數名結構相同的多個函數」。原則是一樣的,保證邏輯正確的前提下,盡可能降低用戶負擔。

對了,關于 getElements 那三個 API,它們最終的進化版本回到了同一個函數:querySelector(selectors)。

使返回值可預期
函數的易用性體現在兩方面:入口和出口。上面已經講述了足夠多關于入口的設計事項,這一節講出口:函數返回值。

對于 getter 型的函數來說,調用的直接目的就是為了獲得返回值。因此我們要讓返回值的類型和函數名的期望保持一致。

// expect ‘a.b.c.d’
function getSPMInString() {

// fail
return {
a, b, c, d
};
}
從這一點上來講,要慎用 ES2015 中的新特性「解構賦值」。

而對于 setter 型的函數,調用的期望是它能執行一系列的指令,然后去達到一些副作用,比如存文件、改寫變量值等等。因此絕大多數情況我們都選擇了返回 undefined / void —— 這并不總是最好的選擇。

回想一下,我們在調用操作系統的命令時,系統總會返回「exit code」,這讓我們能夠獲知系統命令的執行結果如何,而不必通過其他手段去驗證「這個操作到底生效了沒」。因此,創建這樣一種返回值風格,或可一定程度增加健壯性。

另外一個選項,是讓 setter 型 API 始終返回 this。這是 jQuery 為我們帶來的經典啟示 —— 通過返回 this,來產生一種「鏈式調用(chaining)」的風格,簡化代碼并且增加可讀性:

$(‘div’)
.attr(‘foo’, ‘bar’)
.data(‘hello’, ‘world’)
.on(‘click’, function() {});
最后還有一個異類,就是異步執行的函數。由于異步的特性,對于這種需要一定延時才能得到的返回值,只能使用 callback 來繼續操作。使用 Promise 來包裝它們尤為必要。對異步操作都返回一個 Promise,使整體的 API 風格更可預期。

固化術語表
在前面的詞法部分中曾經提到「準確用詞」,但即使我們已經盡量去用恰當的詞,在有些情況下仍然不免碰到一些難以抉擇的尷尬場景。

比如,我們經常會看到 pic 和 image、path 和 url 混用的情況,這兩組詞的意思非常接近(當然嚴格來說 path 和 url 的意義是明確不同的,在此暫且忽略),稍不留神就會產生 4 種組合……

picUrl
picPath
imageUrl
imagePath
更糟糕的情況是 imgUrl、picUri、picURL……
所以,在一開始就要 產出術語表,包括對縮寫詞的大小寫如何處理、是否有自定義的縮寫詞等等。一個術語表可以形如:

標準術語 含義 禁用的非標準詞
pic 圖片 image, picture
path 路徑 URL, url, uri
on 綁定事件 bind, addEventListener
off 解綁事件 unbind, removeEventListener
emit 觸發事件 fire, trigger
module 模塊 mod
不僅在公開的 API 中要遵守術語表規范,在局部變量甚至字符串中都最好按照術語表來。

page.emit(‘pageRenderRow’, {
index: this.props.index,
modList: moduleList
});
比如這個我最近碰到的案例,同時寫作了 modList 和 moduleList,這就有點怪怪的。

另外,對于一些創造出來的、業務特色的詞匯,如果不能用英語簡明地翻譯,就直接用拼音:

淘寶 Taobao
微淘 Weitao
極有家 Jiyoujia
……
在這里,千萬不要把「微淘」翻譯為 MicroTaobao……當然,專有詞已經有英文名的除外,如 Tmall。

遵循一致的 API 風格
這一節算得上是一個復習章節。詞法、語法、語義中的很多節都指向同一個要點:一致性。

一致性可以最大程度降低信息熵。
好吧,這句話不是什么名人名言,就是我現編的。總而言之,一致性能大大降低用戶的學習成本,并對 API 產生準確的預期。

在詞法上,提煉術語表,全局保持一致的用詞,避免出現不同的但是含義相近的詞。
在語法上,遵循統一的語法結構(主謂賓順序、主被動語態),避免天馬行空的造句。
在語義上,合理運用函數的重載,提供可預期的甚至一致類型的函數入口和出口。
甚至還可以一致得更細節些,只是舉些例子:

打 log 要么都用中文,要么都用英文。
異步接口要么都用回調,要么都改成 Promise。
事件機制只能選擇其一:object.onDoSomething = func 或 object.on(‘doSomething’, func)。
所有的 setter 操作必須返回 this。
……
一份代碼寫得再怎么爛,把某個單詞都拼成一樣的錯誤,也好過這個單詞只出現一次錯誤。
是的,一致性,再怎么強調都不為過。

卓越:系統性和大局觀
不管是大到發布至業界,或小到在公司內跨部門使用,一組 API 一旦公開,整體上就是一個產品,而調用方就是用戶。所謂牽一發而動全身,一個小細節可能影響整個產品的面貌,一個小改動也可能引發整個產品崩壞。因此,我們一定要站在全局的層面,甚至考慮整個技術環境,系統性地把握整個體系內 API 的設計,體現大局觀。

版本控制
80% 的項目開發在版本控制方面做得都很糟糕:隨心所欲的版本命名、空洞詭異的提交信息、毫無規劃的功能更新……人們顯然需要一段時間來培養規范化開發的風度,但是至少得先保證一件事情:

在大版本號不變的情況下,API 保證向前兼容。
這里說的「大版本號」即「語義化版本命名」.. 中的第一位 位。

這一位的改動表明 API 整體有大的改動,很可能不兼容,因此用戶對大版本的依賴改動會慎之又慎;反之,如果 API 有不兼容的改動,意味著必須修改大版本號,否則用戶很容易出現在例行更新依賴后整個系統跑不起來的情況,更糟糕的情況則是引發線上故障。

如果這種情況得不到改善,用戶們就會選擇 永遠不升級依賴,導致更多的潛在問題。久而久之,最終他們便會棄用這些產品(庫、中間件、whatever)。

所以,希望 API 的提供者們以后不會再將大版本鎖定為 0。更多關于「語義化版本」的內容,請參考我的另一篇文章《論版本號的正確打開方式》。

確保向下兼容
如果不希望對客戶造成更新升級方面的困擾,我們首先要做好的就是確保 API 向下兼容。

API 發生改動,要么是需要提供新的功能,要么是為之前的糟糕設計買單……具體來說,改動無外乎:增加、刪除、修改 三方面。

首先是刪除。不要輕易刪除公開發布的 API,無論之前寫得多么糟糕。如果一定要刪除,那么確保正確使用了「Deprecated」:

對于某個不想保留的可憐 API,先不要直接刪除,將其標記為 @deprecated 后置入下一個小版本升級(比如從 1.0.2 到 1.1.0)。

/**
* @deprecated
*/
export function youWantToRemove(foo, bar) {}

/**
* This is the replacement.
*/
export function youWantToKeep(foo) {}
并且,在 changelog 中明確指出這些 API 即將移除(不推薦使用,但是目前仍然能用)。關于 changelog 的寫法建議可參考 更新日志的寫法規范。

之后,在下一個 大版本 中(比如 1.1.0 到 2.0.0)刪除標記為 @deprecated 的部分,同時在 changelog 中指明它們已刪除。

其次是 API 的修改。如果我們僅僅是修復 bug、重構實現、或者添加一些小特性,那自然沒什么可說的;但是如果想徹底修改一個 API……比如重做入口參數、改寫業務邏輯等等,建議的做法是:

確保原來的 API 符合「單一職責」原則,如果不是則修改之。
增加一個全新的 API 去實現新的需求!由于我們的 API 都遵循「單一職責」,因此一旦需要徹底修改 API,意味著新需求和原來的職責已經完全無法匹配,不如干脆新增一個 API。
視具體情況選擇保留或移除舊 API,進入前面所述「刪除 API」的流程。
最后是新增 API。事實上,即使是只加代碼不刪代碼,整體也不一定是向下兼容的。有一個經典的正面案例是:

// modern browsers
document.hidden == false;

// out-of-date browsers
document.hidden == undefined;
瀏覽器新增的一個 API,用以標記「當前文檔是否可見」。直觀的設計應該是新增 document.visible 這樣的屬性名……問題是,在邏輯上,文檔默認是可見的,即 document.visible 默認為 true,而不支持此新屬性的舊瀏覽器返回 document.visible == undefined,是個 falsy 值。因此,如果用戶在代碼中簡單地以:

if (document.visible) {
// do some stuff
}
做特征檢測的話,在舊瀏覽器中就會進入錯誤的條件分支……而反之,以 document.hidden API 來判斷,則是向下兼容的。

設計擴展機制
毫無疑問,在保證向下兼容的同時,API 需要有一個對應的擴展機制以可持續發展 —— 一方面便于開發者自身增加功能,另一方面用戶也能參與進來共建生態。

技術上來說,接口的擴展方式有很多,比如:繼承(extend)、組合(mixin)、裝飾(decorate)……選擇沒有對錯,因為不同的擴展方式適用于不同的場景:在邏輯上確實存在派生關系,并且需要沿用基類行為同時自定義行為的,采用重量級的繼承;僅僅是擴充一些行為功能,但是邏輯上壓根不存在父子關系的,使用組合;而裝飾手法更多應用于給定一個接口,將其包裝成多種適用于不同場景新接口的情況……

另一方面,對于不同的編程語言來說,由于不同的語言特性……靜態、動態等,各自更適合用某幾種擴展方式。所以,到底采用什么擴展辦法,還是得視情況而定。

在 JS 界,有一些經典的技術產品,它們的擴展甚至已經形成生態,如:

jQuery。耳熟能詳的 $.fn.customMethod = function() {};。這種簡單的 mixin 做法已經為 jQuery 提供了成千上萬的插件,而 jQuery 自己的大部分 API 本身也是基于這個寫法構建起來的。
React。React 自身已經處理了所有有關組件實例化、生命周期、渲染和更新等繁瑣的事項,只要開發者基于 React.Component 來繼承出一個組件類。對于一個 component system 來說,這是一個經典的做法。
Gulp。相比于近兩年的大熱 Webpack,個人認為 Gulp 更能體現一個 building system 的邏輯 —— 定義各種各樣的「任務」,然后用「管道」將它們串起來。一個 Gulp 插件也是那么的純粹,接受文件流,返回文件流,如是而已。
Koa。對于主流的 HTTP Server 來說,中間件的設計大同小異:接受上一個 request,返回一個新的 response。而對天生 Promise 化的 Koa 來說,它的中間件風格更接近于 Gulp 了,區別僅在于一個是 file stream,一個是 HTTP stream。
不只是龐大的框架需要考慮擴展性,設計可擴展的 API 應該變成一種基本的思維方式。比如這個活生生的業務例子:

// json
[
{
“type”: “item”,
“otherAttrs”: “foo”
},
{
“type”: “shop”,
“otherAttrs”: “bar”
}
]

// render logic
switch(feed.type) {
case ‘item’:
console.log(‘render in item-style.’);
break;
case ‘shop’:
console.log(‘render in shop-style.’);
break;
case ‘other’:
default:
console.log(‘render in other styles, maybe banner or sth.’);
break;
}
根據不同的類型渲染一組 feeds 信息:商品模塊、店鋪模塊,或是其他。某天新增了需求說要支持渲染天貓的店鋪模塊(多顯示個天貓標等等),于是 JSON 接口直接新增一個 type = ‘tmallShop’ —— 這種接口改法很簡單直觀,但是并不好。在不改前端代碼的情況下,tmallShop 類型默認進入 default 分支,導致奇奇怪怪的渲染結果。

考慮到 tmallShop 和 shop 之間是一個繼承的關系,tmallShop 完全可以當一個普通的 shop 來用,執行后者的所有邏輯。用 Java 的表達方式來說就是:

// a tmallShop is a shop
Shop tmallShop = new TmallShop();
tmallShop.doSomeShopStuff();
將這個邏輯關系反映到 JSON 接口中,合理的做法是新增一個 subType 字段,用來標記 tmallShop,而它的 type 仍然保持為 shop。這樣一來,即使原來的前端代碼完全不修改,仍然可以正常運行,除了無法渲染出一些天貓店鋪的特征。

這里還有一個非常類似的正面案例,是 ABS 搭建系統(淘寶 FED 出品的站點搭建系統)設計的模塊 JSON Schema:

// json
[
{
“type”: “string”,
“format”: “enum”
}, {
“type”: “string”,
“format”: “URL”
}
]
同樣采用了 type 為主類型,而擴展字段在這里變成了 format,用來容納一些擴展特性。在實際開發中,的確也很方便新增各種新的數據結構邏輯。

控制 API 的抽象級別
API 能擴展的前提是什么?是接口足夠抽象。這樣才能夠加上各種具體的定語、裝飾更多功能。用日常語言舉個例子:

// abstract
I want to go to a place.
// when
{Today, Tomorrow, Jan. 1st} I want to go to a place.
// where
I want to go to {mall, cafe, bed}.

// concrete, no extends any more
Today I want to go to a cafe for my business.
所以,在設計 API 時要高抽象,不要陷入具體的實現,不要陷入具體的需求,要高屋建瓴。

看個實際的案例:一個類 React Native 的頁面框架想暴露出一個事件「滾動到第二屏」,以便頁面開發者能監聽這個事件,從而更好地控制頁面資源的加載策略(比如首屏默認加載渲染、到第二屏之后再去加載剩下的資源)。

但是因為一些實現上的原因,頁面框架還不能通過頁面位移(offset)來精確地通知「滾動到了第二屏」,而只能判斷「第二屏的第一個模塊出現了」。于是這個事件沒有被設計為 secondScreenReached,而變成了 secondScreenFirstModuleAppear……雖然 secondScreenFirstModuleAppear 不能精確定義 secondScreenReached,但是直接暴露這個具體的 API 實在太糟糕了,問題在于:

用戶在依賴一個非常非常具體的 API,給用戶造成了額外的信息負擔。「第二屏的第一個模塊出現了!」這很怪異,用戶根本不關心模塊的事情,用戶關心的只是他是否到達了第二屏。
一旦頁面框架能夠真正通過頁面位移來實現「滾動到第二屏」,如果我們暴露的是高抽象的 secondScreenReached,那么只需要更改一下這個接口的具體實現即可;反之,我們暴露的是很具體的 secondScreenFirstModuleAppear,就只能挨個通知用戶:「你現在可以不用依賴這個事件了,改成我們新出的 secondScreenReached 吧!」
是的,抽象級別一般來說越高越好,將 API 設計成業務無關的,更通用,而且方便擴展。但是物極必反,對于像我這樣的抽象控來說,最好能學會控制接口的抽象級別,將其保持在一個恰到好處的層次上,不要做無休止的抽象。

還是剛才的例子 secondScreenReached,我們還可以將其抽象成 targetScreenReached,可以支持到達首屏、到達第二屏、第三屏……的事件,這樣是不是更靈活、更優雅呢?并沒有 ——

抽象時一定要考慮到具體的業務需求場景,有些實現路徑如果永遠不可能走到,就沒必要抽出來。比如這個例子中,沒有人會去關心第三屏、第四屏的事件。
太高的抽象容易造成太多的層次,帶來額外的耦合、通信等不同層次之間的溝通成本,這將會成為新的麻煩。對用戶而言,也是額外的信息負擔。
對于特定的業務來說,接口越抽象越通用,而越具體則越能解決特定問題。所以,思考清楚,API 面向的場景范圍,避免懶惰設計,避免過度設計。

收斂 API 集
對于一整個體系的 API 來說,用戶面對的是這個整體集合,而不是其中某幾個單一的 API。我們要保證集合內的 API 都在一致的抽象維度上,并且適當地合并 API,減小整個集合的信息量,酌情做減法。

產品開始做減法,便是對用戶的溫柔。
收斂近似意義的參數和局部變量。下面這樣的一組 API 好像沒什么不對,但是對強迫癥來說一定產生了不祥的直覺:

export function selectTab(index) {}

export function highlightTab(tabIndex) {}

export function gotoPage(index) {}
又是 index 又是 tabIndex 的,或許還會有 pageIndex?誠然,函數形參和局部變量的命名對最終用戶來說沒有直接影響,但是這些不一致的寫法仍然能反映到 API 文檔中,并且,對開發者自身也會產生混淆。所以,選一個固定的命名風格,然后從一而終!如果忘了的話,回頭看一下前文「固化術語表」這一節吧!

收斂近似職責的函數。對用戶暴露出太多的接口不是好事,但是一旦要合并不同的函數,是否就會破壞「單一職責」原則呢?

不,因為「單一職責」本身也要看具體的抽象層次。以下這個例子和前文「合理運用函數重載」中的例子有相似之處,但具體又有所不同。

// a complex rendering process
function renderPage() {

// too many APIs here
renderHeader();
renderBody();
renderSidebar();
renderFooter();
}

// now merged
function renderPage() {
renderSections([
‘header’, ‘body’, ‘sidebar’, ‘footer’
]);
}

// call renderSection
function renderSections(sections) {}

// and the real labor
function renderSection(section) {}
類似于這樣,避免暴露過多近似的 API,合理利用抽象將其合并,減小對用戶的壓力。

對于一個有清晰繼承樹的場景來說,收斂 API 顯得更加自然且意義重大 —— 利用多態性(Polymorphism)構建 Consistent APIs。(以下例子來源于 Clean Code JS。)

// bad: type-checking here
function travelToTexas(vehicle) {
if (vehicle instanceof Bicycle) {
vehicle.pedal(this.currentLocation, new Location(‘texas’));
} else if (vehicle instanceof Car) {
vehicle.drive(this.currentLocation, new Location(‘texas’));
}
}

// cool
function travelToTexas(vehicle) {
vehicle.move(this.currentLocation, new Location(‘texas’));
}
有一個將 API 收斂到極致的家伙恐怕大家都不會陌生:jQuery 的 $()。這個風格不正是 jQuery 當年的殺手級特性之一嗎?

如果 $() 能讓我搞定這件事,就不要再給我 foo() 和 bar()。
收斂近似功能的包。再往上一級,我們甚至可以合并相近的 package。

淘寶 FED 的 Rax 體系(類 RN 框架)中,有基礎的組件標簽,如 (in @ali/rax-components)、 (in @ali/rax-components),也有一些增強功能的 package,如 (in @ali/rax-picture)、 (in @ali/rax-spmlink)。

在這里,后者包之于前者相當于裝飾了更多功能,是前者的增強版。而在實際應用中,也是推薦使用諸如 而禁止使用 。那么在這種大環境下, 等基礎 API 的暴露就反而變得很擾民。可以考慮將增強包的功能完全合并入基礎組件,即將 并入 ,用戶只需面對單一的、標準的組件 API。

發散 API 集
這聽上去很荒謬,為什么一個 API 集合又要收斂又要發散?僅僅是為了大綱上的對稱性嗎?

當然不是。存在這個小節是因為我有一個不得不提的案例,不適合放在其他段落,只能放在這里……不,言歸正傳,我們有時的確需要發散 API 集,提供幾個看似接近的 API,以引導用戶。因為 —— 雖然這聽起來很荒謬 —— 某些情況下,API 其實不夠用,但是用戶 沒有意識到 API 不夠用,而是選擇了混用、濫用。看下面這個例子:

// the func is used here
requestAnimationFrame(() => {

// what? trigger an event?
emitter.emit(‘moduleDidRenderRow’);
});

// …and there
requestAnimationFrame(() => {

// another one here, I guess rendering?
this.setState({
// …
});
});
在重構一組代碼時,我看到代碼里充斥著 requestAnimationFrame(),這是一個比較新的全局 API,它會以接近 60 FPS 的速率延時執行一個傳入的函數,類似于一個針對特定場景優化過的 setTimeout(),但它的初衷是用來繪制動畫幀的,而不應該用在奇奇怪怪的場景中。

在深入地了解了代碼邏輯之后,我認識到這里如此調用是為了「延時一丟丟執行一些操作」,避免阻塞主渲染線程。然而這種情況下,還不如直接調用 setTimeout() 來做延時操作。雖然沒有太明確的語義,但是至少好過把自己偽裝成一次動畫的繪制。更可怕的是,據我所知 requestAnimationFrame() 的濫用不僅出現在這次重構的代碼中,我至少在三個不同的庫見過它的身影 —— 無一例外地,這些庫和動畫并沒有什么關系。

(一個可能的推斷是,調用 requestAnimationFrame(callback) 時不用指定 timeout 毫秒數,而 setTimeout(callback, timeout) 是需要的。似乎對很多用戶來說,前者的調用方式更 cool?)

所以,在市面上有一些 API 好像是「偏方」一般的存在:雖然不知道為什么要這么用,但是……用它就對了!

事實上,對于上面這個場景,最恰當的解法是使用一個更加新的 API,叫做 requestIdleCallback(callback)。這個 API 從名字上看起來就很有語義:在線程空閑的時候再執行操作。這完全契合上述場景的需求,而且還自帶底層的優化。

當然,由于 API 比較新,還不是所有的平臺都能支持。即便如此,我們也可以先面向接口編程,自己做一個 polyfill:

// simple polyfill
export function requestIdleCallback(callback) => {
callback && setTimeout(callback, 1e3 / 60);
};
另一個經典的濫用例子是 ES2015 中的「Generator / yield」。

原本使用場景非常有限的生成器 Generator 機制被大神匠心獨運地加以改造,包裝成用來異步代碼同步化的解決方案。這種做法自然很有創意,但是從語義用法上來說實在不足稱道,讓代碼變得非常難讀,并且帶來維護隱患。與其如此,還不如僅僅使用 Promise。

令人欣慰的是,隨后新版的 ES 即提出了新的異步代碼關鍵字「async / await」,真正在語法層面解決了異步代碼同步化的問題,并且,新版的 Node.js 也已經支持這種語法。

因此,我們作為 API 的開發者,一定要提供足夠場景適用的 API,來引導我們的用戶,不要讓他們做出一些出人意料的「妙用」之舉。

制定 API 的支持策略
我們說,一組公開的 API 是產品。而產品,一定有特定的用戶群,或是全球的開發者,或僅僅是跨部門的同事;產品同時有保質期,或者說,生命周期。

面向目標用戶群體,我們要制定 API 的支持策略:

每一個大版本的支持周期是多久。
是否有長期穩定的 API 支持版本。(Long-term Support)
如何從舊版本升級。
老舊版本很可能還在運行,但維護者已經沒時間精力再去管這些歷史遺物,這時明確地指出某些版本不再維護,對開發者和用戶都好。當然,同時別忘了給出升級文檔,指導老用戶如何遷移到新版本。還有一個更好的做法是,在我們開啟一個新版本之際,就確定好上一個版本的壽命終點,提前知會到用戶。

還有一個技術上的注意事項,那就是:大版本間最好有明確的隔離。對于一個復雜的技術產品來說,API 只是最終直接面向用戶的接口,背后還有特定的環境、工具組、依賴包等各種支撐,互相之間并不能混用。

比如,曾經的經典前端庫 KISSY。在業界技術方案日新月異的大潮下,KISSY 6 版本已經強依賴了 TNPM(阿里內網的 NPM)、DEF 套件組(淘寶 FED 的前端工具套件),雖然和之前的 1.4 版本相比 API 的變化并不大,但是仍然不能在老環境下直接使用 6 版本的代碼庫……這一定程度上降低了自由組合的靈活度,但事實上隨著業務問題場景的復雜度提升,解決方案本身會需要更定制化,因此,將環境、工具等上下游關聯物隨代碼一起打包,做成一整個技術方案,這正是業界的現狀。

所以,隔離大版本,制定好 API 支持策略,讓我們的產品更專業,讓用戶免去后顧之憂。

總結
以上,便是我從業以來感悟到的一些「道」,三個進階層次、幾十個細分要點,不知有沒有給讀者您帶來一丁點啟發。

但實際上,大道至簡。我一直認為,程序開發和平時的說話寫字其實沒有太大區別,無非三者 ——

邏輯和抽象。
領域知識。
語感。
寫代碼,就像寫作,而設計 API 好比列提綱。勤寫、勤思,了解前人的模式、套路,學習一些流行庫的設計方法,掌握英語、提高語感……相信大家都能設計出卓越的 API。

最后,附上 API 設計的經典原則:

Think about future, design with flexibility, but only implement for production.
引用
Framework Design Guidelines
Page Visibility 的 API 設計
我心目中的優秀 API
Clean Code JavaScript
題圖:只是一張符合上下文的圖片,并沒有更深的含義。

花絮:由于文章很長,在編寫過程中我也不由得發生了「同一個意思卻使用多種表達方式」的情況。某些時候這是必要的 —— 可以豐富文字的多樣性;而有些時候,則顯得全文缺乏一致性。在發表本文之前,我搜索了這些詞語:「調用者」、「調用方」、「引用者」、「使用者」,然后將它們統一修改為我們熟悉的名字:「用戶」。

總結

以上是生活随笔為你收集整理的从达标到卓越 —— API 设计之道的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

人妻有码中文字幕在线 | 国内精品久久久久久中文字幕 | 久久精品无码一区二区三区 | 亚拍精品一区二区三区探花 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产精品久久久av久久久 | 中文无码成人免费视频在线观看 | 欧美性生交xxxxx久久久 | 三上悠亚人妻中文字幕在线 | 国产精品人人爽人人做我的可爱 | 成熟妇人a片免费看网站 | 99久久亚洲精品无码毛片 | 东京热一精品无码av | 亚洲一区二区三区香蕉 | 婷婷五月综合缴情在线视频 | 小鲜肉自慰网站xnxx | 中文字幕乱码人妻二区三区 | √天堂中文官网8在线 | 综合激情五月综合激情五月激情1 | 国产精品无码一区二区三区不卡 | 亚洲日韩av一区二区三区中文 | 成人片黄网站色大片免费观看 | av在线亚洲欧洲日产一区二区 | 国产9 9在线 | 中文 | 日本一区二区更新不卡 | 亚洲а∨天堂久久精品2021 | 久久亚洲精品中文字幕无男同 | 水蜜桃亚洲一二三四在线 | 曰韩少妇内射免费播放 | 呦交小u女精品视频 | 377p欧洲日本亚洲大胆 | 中文无码精品a∨在线观看不卡 | 国产 浪潮av性色四虎 | 国产电影无码午夜在线播放 | 亚洲乱码日产精品bd | 国产精品第一国产精品 | 日韩精品成人一区二区三区 | 精品国产青草久久久久福利 | 欧美日韩一区二区三区自拍 | 亚洲国产午夜精品理论片 | 成人性做爰aaa片免费看 | 六月丁香婷婷色狠狠久久 | 国产精品久久久一区二区三区 | 一本大道久久东京热无码av | 国产偷自视频区视频 | 99国产精品白浆在线观看免费 | 国产一区二区三区四区五区加勒比 | 无码人妻出轨黑人中文字幕 | 国产xxx69麻豆国语对白 | 中文字幕av日韩精品一区二区 | aⅴ在线视频男人的天堂 | 免费无码午夜福利片69 | 久久综合九色综合97网 | 国产尤物精品视频 | 亚洲狠狠色丁香婷婷综合 | 久久精品人妻少妇一区二区三区 | 色婷婷综合中文久久一本 | 免费无码一区二区三区蜜桃大 | 亚洲乱亚洲乱妇50p | 色老头在线一区二区三区 | 麻豆成人精品国产免费 | 精品成人av一区二区三区 | 色诱久久久久综合网ywww | 欧美性猛交内射兽交老熟妇 | 久久伊人色av天堂九九小黄鸭 | 熟女少妇人妻中文字幕 | 人人爽人人澡人人高潮 | 国产肉丝袜在线观看 | 丰满肥臀大屁股熟妇激情视频 | 女人被爽到呻吟gif动态图视看 | 精品国产av色一区二区深夜久久 | 国产精品久久久久久亚洲毛片 | 亚洲a无码综合a国产av中文 | 久久久精品国产sm最大网站 | 亚洲欧美综合区丁香五月小说 | 天天综合网天天综合色 | 国产在线精品一区二区三区直播 | 亚洲一区二区三区无码久久 | 麻豆成人精品国产免费 | 亚洲区欧美区综合区自拍区 | 久久精品99久久香蕉国产色戒 | 在线播放无码字幕亚洲 | 中文字幕人成乱码熟女app | 波多野结衣 黑人 | 一区二区三区高清视频一 | 亚洲日本va午夜在线电影 | 久久无码中文字幕免费影院蜜桃 | 国产成人无码av片在线观看不卡 | 婷婷六月久久综合丁香 | 亚洲精品午夜国产va久久成人 | 蜜臀av无码人妻精品 | 美女黄网站人色视频免费国产 | 国产又爽又黄又刺激的视频 | 日本护士xxxxhd少妇 | 亚洲高清偷拍一区二区三区 | 亚洲乱亚洲乱妇50p | 国产精华av午夜在线观看 | 欧美人与善在线com | a片在线免费观看 | 亚洲色无码一区二区三区 | 三上悠亚人妻中文字幕在线 | 内射老妇bbwx0c0ck | 撕开奶罩揉吮奶头视频 | 欧美国产亚洲日韩在线二区 | 亚洲一区av无码专区在线观看 | 日本成熟视频免费视频 | 久久亚洲中文字幕精品一区 | 亚洲一区二区三区在线观看网站 | 日韩精品无码免费一区二区三区 | 少妇久久久久久人妻无码 | 成人性做爰aaa片免费看不忠 | 久久无码中文字幕免费影院蜜桃 | 国产精品久久久久9999小说 | 疯狂三人交性欧美 | 99久久无码一区人妻 | www国产亚洲精品久久久日本 | 东京无码熟妇人妻av在线网址 | 久激情内射婷内射蜜桃人妖 | 国产无av码在线观看 | 亚洲区小说区激情区图片区 | 综合激情五月综合激情五月激情1 | 欧美成人家庭影院 | 国产在线无码精品电影网 | 四虎影视成人永久免费观看视频 | 国产亚洲视频中文字幕97精品 | 久久久久久九九精品久 | 极品嫩模高潮叫床 | 18黄暴禁片在线观看 | 欧美日韩精品 | 在线播放亚洲第一字幕 | 又大又硬又黄的免费视频 | 综合激情五月综合激情五月激情1 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 在线 国产 欧美 亚洲 天堂 | 无码精品国产va在线观看dvd | 精品一二三区久久aaa片 | 亚洲精品午夜无码电影网 | 狠狠色噜噜狠狠狠7777奇米 | 国产熟女一区二区三区四区五区 | 大肉大捧一进一出好爽视频 | 精品国偷自产在线视频 | 国产在热线精品视频 | 人妻少妇精品视频专区 | 国产特级毛片aaaaaaa高清 | 国产精品第一国产精品 | 亚洲精品久久久久久久久久久 | av无码不卡在线观看免费 | 亚洲精品鲁一鲁一区二区三区 | 日韩av激情在线观看 | 日本熟妇人妻xxxxx人hd | 1000部啪啪未满十八勿入下载 | 国内综合精品午夜久久资源 | 亚洲一区二区三区在线观看网站 | 国产 精品 自在自线 | 99久久精品国产一区二区蜜芽 | 久久国产精品二国产精品 | 黑人粗大猛烈进出高潮视频 | 精品无人区无码乱码毛片国产 | √天堂资源地址中文在线 | 免费国产成人高清在线观看网站 | 国产绳艺sm调教室论坛 | 亚洲色欲久久久综合网东京热 | 国产精品人妻一区二区三区四 | 色一情一乱一伦一区二区三欧美 | 精品少妇爆乳无码av无码专区 | 国产又粗又硬又大爽黄老大爷视 | 日日鲁鲁鲁夜夜爽爽狠狠 | 欧美一区二区三区视频在线观看 | 四虎影视成人永久免费观看视频 | 伊人久久婷婷五月综合97色 | 欧美刺激性大交 | 大色综合色综合网站 | 夜夜躁日日躁狠狠久久av | 狠狠cao日日穞夜夜穞av | 欧美国产日韩久久mv | 天堂久久天堂av色综合 | 日本护士毛茸茸高潮 | 亚洲码国产精品高潮在线 | 亚洲色欲久久久综合网东京热 | 亚洲国产欧美日韩精品一区二区三区 | 国产乱人偷精品人妻a片 | 日本护士xxxxhd少妇 | 青青青爽视频在线观看 | 国产精品爱久久久久久久 | 精品国产aⅴ无码一区二区 | 色噜噜亚洲男人的天堂 | 国内精品一区二区三区不卡 | 成人综合网亚洲伊人 | 亚洲人成人无码网www国产 | 国产小呦泬泬99精品 | 牲交欧美兽交欧美 | 欧美35页视频在线观看 | 人人妻人人藻人人爽欧美一区 | 狂野欧美性猛xxxx乱大交 | 国产高清不卡无码视频 | 亚洲精品国产精品乱码不卡 | 少妇高潮喷潮久久久影院 | 亚洲国产av美女网站 | 亚洲 激情 小说 另类 欧美 | 一个人免费观看的www视频 | 国产精品无码永久免费888 | 人妻少妇精品无码专区二区 | 国产在线精品一区二区三区直播 | 精品久久久无码人妻字幂 | 一本久久a久久精品vr综合 | 国产热a欧美热a在线视频 | 熟女少妇在线视频播放 | 国产色xx群视频射精 | 美女极度色诱视频国产 | 俺去俺来也www色官网 | 波多野结衣av一区二区全免费观看 | 欧美刺激性大交 | 国产成人久久精品流白浆 | 无码人妻丰满熟妇区五十路百度 | 乱码av麻豆丝袜熟女系列 | 欧美自拍另类欧美综合图片区 | 夜夜高潮次次欢爽av女 | 乱人伦人妻中文字幕无码 | 又黄又爽又色的视频 | 水蜜桃亚洲一二三四在线 | 成年美女黄网站色大免费全看 | 两性色午夜视频免费播放 | 国产av人人夜夜澡人人爽麻豆 | 精品偷拍一区二区三区在线看 | 日本欧美一区二区三区乱码 | 丰满护士巨好爽好大乳 | 狂野欧美性猛交免费视频 | 色五月五月丁香亚洲综合网 | 国产亚洲人成a在线v网站 | 久久人人爽人人爽人人片ⅴ | 午夜精品一区二区三区在线观看 | 亚洲精品一区二区三区在线观看 | 无码人中文字幕 | 免费看少妇作爱视频 | 免费无码肉片在线观看 | 日日夜夜撸啊撸 | 欧美国产日韩亚洲中文 | 国产精品免费大片 | 国产成人人人97超碰超爽8 | 老太婆性杂交欧美肥老太 | 久青草影院在线观看国产 | 久久久成人毛片无码 | 国产高清av在线播放 | 97精品人妻一区二区三区香蕉 | 久久午夜无码鲁丝片秋霞 | 又粗又大又硬又长又爽 | 老熟妇仑乱视频一区二区 | 精品欧洲av无码一区二区三区 | 色综合久久中文娱乐网 | 免费网站看v片在线18禁无码 | 国产午夜视频在线观看 | 狠狠色噜噜狠狠狠7777奇米 | 最新国产麻豆aⅴ精品无码 | 特黄特色大片免费播放器图片 | 荫蒂添的好舒服视频囗交 | 伊人久久大香线蕉午夜 | 国产精品久久久久9999小说 | 女人高潮内射99精品 | 99久久精品无码一区二区毛片 | 国产香蕉尹人综合在线观看 | 97精品国产97久久久久久免费 | 国产亚洲精品久久久久久 | 日韩视频 中文字幕 视频一区 | 欧美阿v高清资源不卡在线播放 | 无码av最新清无码专区吞精 | 久久aⅴ免费观看 | 丰满少妇人妻久久久久久 | 少妇人妻av毛片在线看 | 麻豆国产人妻欲求不满谁演的 | 日本一卡2卡3卡四卡精品网站 | 人妻天天爽夜夜爽一区二区 | 国产亚洲精品久久久久久久 | 强开小婷嫩苞又嫩又紧视频 | 亚洲精品欧美二区三区中文字幕 | 乌克兰少妇xxxx做受 | 久久精品国产99久久6动漫 | 久久亚洲中文字幕精品一区 | 中文字幕乱码人妻无码久久 | 女人色极品影院 | 无码国模国产在线观看 | 午夜精品一区二区三区的区别 | 欧美一区二区三区视频在线观看 | 免费男性肉肉影院 | 久久久久99精品成人片 | 亚洲国产欧美国产综合一区 | 欧美高清在线精品一区 | 妺妺窝人体色www婷婷 | 伊人久久大香线蕉av一区二区 | 精品人妻人人做人人爽 | 日本一区二区三区免费高清 | 亚洲欧美日韩成人高清在线一区 | 国产肉丝袜在线观看 | 久久久婷婷五月亚洲97号色 | 成人免费无码大片a毛片 | 偷窥村妇洗澡毛毛多 | 999久久久国产精品消防器材 | 国内少妇偷人精品视频免费 | 亚洲一区二区三区偷拍女厕 | 无遮挡啪啪摇乳动态图 | 国产av无码专区亚洲awww | √天堂资源地址中文在线 | 久久久久亚洲精品中文字幕 | 欧美精品无码一区二区三区 | 国产精品久久久一区二区三区 | 无码av免费一区二区三区试看 | √8天堂资源地址中文在线 | 理论片87福利理论电影 | 九一九色国产 | 亚洲精品一区二区三区在线 | 人妻无码久久精品人妻 | 色诱久久久久综合网ywww | 一个人看的视频www在线 | 人妻与老人中文字幕 | 熟女俱乐部五十路六十路av | 国产精品二区一区二区aⅴ污介绍 | 国产麻豆精品一区二区三区v视界 | 老熟妇乱子伦牲交视频 | 亚洲国产av精品一区二区蜜芽 | 欧美亚洲国产一区二区三区 | 久久精品99久久香蕉国产色戒 | 狠狠噜狠狠狠狠丁香五月 | 久久精品99久久香蕉国产色戒 | 久久久久免费精品国产 | 少妇无码av无码专区在线观看 | 国产精品免费大片 | 久久久中文久久久无码 | 宝宝好涨水快流出来免费视频 | 乱人伦中文视频在线观看 | 精品偷自拍另类在线观看 | 久久国内精品自在自线 | 永久免费观看美女裸体的网站 | 131美女爱做视频 | √天堂资源地址中文在线 | 国产午夜福利100集发布 | 澳门永久av免费网站 | 久久熟妇人妻午夜寂寞影院 | 日韩精品无码免费一区二区三区 | 学生妹亚洲一区二区 | 2020最新国产自产精品 | 国产亚洲精品久久久久久国模美 | 国产精品永久免费视频 | 18无码粉嫩小泬无套在线观看 | 日日摸日日碰夜夜爽av | 九九在线中文字幕无码 | 欧美国产日韩亚洲中文 | 1000部啪啪未满十八勿入下载 | 美女扒开屁股让男人桶 | 波多野结衣av一区二区全免费观看 | a片在线免费观看 | 超碰97人人做人人爱少妇 | 国内综合精品午夜久久资源 | 亚洲一区二区三区在线观看网站 | 国产免费观看黄av片 | 日本精品久久久久中文字幕 | 精品国产精品久久一区免费式 | 国产精品99爱免费视频 | 亚洲精品无码国产 | 精品国产一区av天美传媒 | 久久无码人妻影院 | 午夜嘿嘿嘿影院 | yw尤物av无码国产在线观看 | 国模大胆一区二区三区 | 久久精品国产精品国产精品污 | 国产亚洲精品久久久久久国模美 | 国产超碰人人爽人人做人人添 | 天天躁日日躁狠狠躁免费麻豆 | 日本在线高清不卡免费播放 | 夜夜高潮次次欢爽av女 | 国产真人无遮挡作爱免费视频 | 国产真实乱对白精彩久久 | 国产成人精品必看 | 亚洲国产欧美国产综合一区 | 亚洲欧美日韩国产精品一区二区 | 成人欧美一区二区三区黑人 | 中文字幕 人妻熟女 | 清纯唯美经典一区二区 | 九九在线中文字幕无码 | 亚洲gv猛男gv无码男同 | 性生交片免费无码看人 | 国产精品久久久久久久影院 | 国产综合色产在线精品 | 成熟人妻av无码专区 | 思思久久99热只有频精品66 | 亚洲成av人综合在线观看 | 一本精品99久久精品77 | 日欧一片内射va在线影院 | 色综合久久网 | 欧美日韩在线亚洲综合国产人 | 日韩成人一区二区三区在线观看 | 男女猛烈xx00免费视频试看 | 日韩欧美成人免费观看 | 国产亚洲精品久久久久久久 | 蜜桃视频插满18在线观看 | 日本精品久久久久中文字幕 | 国产av无码专区亚洲awww | 欧美熟妇另类久久久久久不卡 | 白嫩日本少妇做爰 | 亚洲a无码综合a国产av中文 | 亚洲乱码中文字幕在线 | 亚洲午夜久久久影院 | 国产精品视频免费播放 | 无码人妻少妇伦在线电影 | 女人色极品影院 | 欧美丰满熟妇xxxx | 无码精品国产va在线观看dvd | 一本色道婷婷久久欧美 | 樱花草在线播放免费中文 | 日本熟妇浓毛 | 成人动漫在线观看 | 久久亚洲中文字幕无码 | 极品嫩模高潮叫床 | 老熟女重囗味hdxx69 | 中文字幕无码av波多野吉衣 | 亚洲国产精品久久人人爱 | 国产女主播喷水视频在线观看 | 久久综合激激的五月天 | 好男人www社区 | 欧美xxxxx精品 | 亚洲精品综合五月久久小说 | 久久人人爽人人爽人人片ⅴ | 亚洲国产精品成人久久蜜臀 | 97无码免费人妻超级碰碰夜夜 | 内射后入在线观看一区 | 国产欧美熟妇另类久久久 | 日本大乳高潮视频在线观看 | 51国偷自产一区二区三区 | 国产亚洲精品久久久久久久 | 麻豆精产国品 | 亚洲va中文字幕无码久久不卡 | 国产精品亚洲一区二区三区喷水 | 麻豆蜜桃av蜜臀av色欲av | 国产尤物精品视频 | 久久精品中文字幕大胸 | 国产成人无码一二三区视频 | 女人高潮内射99精品 | 人人妻人人澡人人爽欧美一区九九 | 久久99精品久久久久婷婷 | 性开放的女人aaa片 | 午夜男女很黄的视频 | 国产午夜视频在线观看 | 亚洲国产精品久久久天堂 | 久久精品国产99久久6动漫 | 国产九九九九九九九a片 | 国内丰满熟女出轨videos | 男人和女人高潮免费网站 | 国产一区二区三区日韩精品 | 在线欧美精品一区二区三区 | 国产真人无遮挡作爱免费视频 | 日本免费一区二区三区最新 | 激情综合激情五月俺也去 | 特级做a爰片毛片免费69 | 18黄暴禁片在线观看 | 午夜无码区在线观看 | 亚洲日韩av片在线观看 | 欧洲美熟女乱又伦 | 中文亚洲成a人片在线观看 | 人人爽人人澡人人高潮 | 秋霞特色aa大片 | 搡女人真爽免费视频大全 | 久久成人a毛片免费观看网站 | 三上悠亚人妻中文字幕在线 | 永久免费精品精品永久-夜色 | 午夜理论片yy44880影院 | 亚洲国产成人a精品不卡在线 | 乱人伦人妻中文字幕无码久久网 | 天下第一社区视频www日本 | 国产又粗又硬又大爽黄老大爷视 | 成人精品视频一区二区三区尤物 | 国产成人综合色在线观看网站 | 亚洲第一无码av无码专区 | 久久久久成人精品免费播放动漫 | 131美女爱做视频 | 国产手机在线αⅴ片无码观看 | 最近中文2019字幕第二页 | 亚洲国产av精品一区二区蜜芽 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 亚洲一区二区三区播放 | 免费中文字幕日韩欧美 | 欧美freesex黑人又粗又大 | 天天躁夜夜躁狠狠是什么心态 | 国产精品视频免费播放 | 亚洲成av人综合在线观看 | 亚洲综合无码一区二区三区 | 扒开双腿吃奶呻吟做受视频 | 狠狠综合久久久久综合网 | 波多野结衣乳巨码无在线观看 | 蜜桃视频插满18在线观看 | 亚洲国产精品成人久久蜜臀 | 国产精品视频免费播放 | 中文无码伦av中文字幕 | 九月婷婷人人澡人人添人人爽 | 成人精品视频一区二区三区尤物 | 精品无码国产一区二区三区av | 国产午夜福利100集发布 | 丰满少妇人妻久久久久久 | 精品人妻中文字幕有码在线 | 麻豆果冻传媒2021精品传媒一区下载 | 国产精品对白交换视频 | 麻豆国产人妻欲求不满 | 97精品国产97久久久久久免费 | 欧美三级不卡在线观看 | 欧美日韩色另类综合 | 久久久国产一区二区三区 | 欧美亚洲国产一区二区三区 | 乱人伦人妻中文字幕无码 | 国产精品99久久精品爆乳 | 天堂无码人妻精品一区二区三区 | 成人精品天堂一区二区三区 | 国产色在线 | 国产 | 又湿又紧又大又爽a视频国产 | 久久久久久久女国产乱让韩 | 亚洲一区av无码专区在线观看 | 丁香啪啪综合成人亚洲 | 久久午夜无码鲁丝片午夜精品 | 国产精品久久久久久无码 | 无套内射视频囯产 | 宝宝好涨水快流出来免费视频 | 亚洲人成网站免费播放 | 99久久久无码国产aaa精品 | 精品夜夜澡人妻无码av蜜桃 | 亚拍精品一区二区三区探花 | 波多野结衣av一区二区全免费观看 | 一二三四社区在线中文视频 | 无套内谢老熟女 | 国产又粗又硬又大爽黄老大爷视 | 亚洲精品鲁一鲁一区二区三区 | 国产高清av在线播放 | 欧美亚洲日韩国产人成在线播放 | 久久精品人妻少妇一区二区三区 | 免费人成网站视频在线观看 | 久激情内射婷内射蜜桃人妖 | 欧美喷潮久久久xxxxx | 国产莉萝无码av在线播放 | 久久精品国产一区二区三区 | 天堂亚洲免费视频 | 老司机亚洲精品影院 | 亚洲国产精华液网站w | 精品国产青草久久久久福利 | 欧美喷潮久久久xxxxx | 美女扒开屁股让男人桶 | 强辱丰满人妻hd中文字幕 | 18禁黄网站男男禁片免费观看 | 在线精品国产一区二区三区 | 欧美精品免费观看二区 | 日韩精品乱码av一区二区 | 欧美日韩在线亚洲综合国产人 | 久久久久免费看成人影片 | 国产女主播喷水视频在线观看 | 人人爽人人爽人人片av亚洲 | 久久综合九色综合97网 | 中文字幕无码人妻少妇免费 | 中文字幕乱码中文乱码51精品 | 国产午夜亚洲精品不卡下载 | 亚洲精品www久久久 | 国产人妻人伦精品1国产丝袜 | 99国产欧美久久久精品 | 一本大道久久东京热无码av | 色综合久久久无码中文字幕 | 55夜色66夜色国产精品视频 | 亚洲最大成人网站 | 国产无av码在线观看 | 亚洲一区av无码专区在线观看 | 国产亚洲日韩欧美另类第八页 | 亚洲人成网站在线播放942 | 野狼第一精品社区 | 漂亮人妻洗澡被公强 日日躁 | 色婷婷久久一区二区三区麻豆 | 天堂а√在线中文在线 | www成人国产高清内射 | 国产精品丝袜黑色高跟鞋 | 国产欧美亚洲精品a | 沈阳熟女露脸对白视频 | 老熟女乱子伦 | 亚洲 另类 在线 欧美 制服 | 亚洲午夜久久久影院 | 国产成人无码区免费内射一片色欲 | 欧美人与动性行为视频 | 男人和女人高潮免费网站 | 国产婷婷色一区二区三区在线 | 国产色精品久久人妻 | 成人精品一区二区三区中文字幕 | 国产色视频一区二区三区 | 无码福利日韩神码福利片 | 天堂久久天堂av色综合 | 俺去俺来也在线www色官网 | 亚洲s码欧洲m码国产av | 无码人妻少妇伦在线电影 | 成人精品视频一区二区三区尤物 | 日日麻批免费40分钟无码 | 色狠狠av一区二区三区 | 日日摸天天摸爽爽狠狠97 | 国内精品一区二区三区不卡 | 夜夜躁日日躁狠狠久久av | 国产亚洲精品久久久久久大师 | 少妇高潮一区二区三区99 | 无码人妻av免费一区二区三区 | 久久综合久久自在自线精品自 | 丰满少妇人妻久久久久久 | 午夜肉伦伦影院 | 精品久久久久香蕉网 | 牛和人交xxxx欧美 | 国产舌乚八伦偷品w中 | 高潮毛片无遮挡高清免费 | 久久久精品成人免费观看 | 377p欧洲日本亚洲大胆 | 日韩在线不卡免费视频一区 | 中文字幕人妻无码一夲道 | 天天拍夜夜添久久精品大 | 欧美精品国产综合久久 | 女高中生第一次破苞av | 亚洲呦女专区 | 东京一本一道一二三区 | 3d动漫精品啪啪一区二区中 | 久久精品国产一区二区三区 | 国产乱人伦偷精品视频 | 一本一道久久综合久久 | 亚洲国产精品久久人人爱 | 久久久av男人的天堂 | 日韩 欧美 动漫 国产 制服 | 国内精品久久毛片一区二区 | 国产办公室秘书无码精品99 | 亚洲精品鲁一鲁一区二区三区 | 樱花草在线社区www | 国产精品18久久久久久麻辣 | 97无码免费人妻超级碰碰夜夜 | 99久久久无码国产aaa精品 | 日韩人妻无码一区二区三区久久99 | 熟女体下毛毛黑森林 | 国产精品无码永久免费888 | 久久人人爽人人爽人人片ⅴ | 色婷婷香蕉在线一区二区 | 久久久www成人免费毛片 | 中文无码伦av中文字幕 | 国产精品亚洲一区二区三区喷水 | 2019nv天堂香蕉在线观看 | 夜夜夜高潮夜夜爽夜夜爰爰 | 午夜丰满少妇性开放视频 | 蜜臀av无码人妻精品 | 任你躁在线精品免费 | 国产无套内射久久久国产 | 国产麻豆精品一区二区三区v视界 | 俺去俺来也在线www色官网 | 久久99精品久久久久久动态图 | 欧美老人巨大xxxx做受 | 久久人人爽人人爽人人片av高清 | 无码国内精品人妻少妇 | 久久久中文久久久无码 | 色欲人妻aaaaaaa无码 | 久久午夜夜伦鲁鲁片无码免费 | 亚洲日韩av一区二区三区四区 | 人人超人人超碰超国产 | 国产精品99爱免费视频 | 色综合久久久无码中文字幕 | 日本在线高清不卡免费播放 | 曰韩少妇内射免费播放 | 欧美freesex黑人又粗又大 | 正在播放东北夫妻内射 | 性欧美疯狂xxxxbbbb | 亚洲爆乳无码专区 | 亚洲一区二区三区在线观看网站 | 久久国产精品_国产精品 | 亚洲性无码av中文字幕 | 国产黑色丝袜在线播放 | 国内揄拍国内精品人妻 | 性色av无码免费一区二区三区 | av在线亚洲欧洲日产一区二区 | 亚洲成a人一区二区三区 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 国产精品亚洲а∨无码播放麻豆 | 狠狠色丁香久久婷婷综合五月 | 中文字幕无码视频专区 | 在线播放免费人成毛片乱码 | 欧美兽交xxxx×视频 | 中文字幕精品av一区二区五区 | 又大又硬又爽免费视频 | 成人片黄网站色大片免费观看 | 中国女人内谢69xxxx | 亚洲 激情 小说 另类 欧美 | 又大又硬又爽免费视频 | 国产亚洲视频中文字幕97精品 | 久久精品国产精品国产精品污 | 性开放的女人aaa片 | 999久久久国产精品消防器材 | 亚洲精品一区二区三区在线 | 亚洲狠狠婷婷综合久久 | 国产精品无码一区二区桃花视频 | 精品厕所偷拍各类美女tp嘘嘘 | 日本大香伊一区二区三区 | 国产精品久久精品三级 | 中文字幕日韩精品一区二区三区 | 国产亚洲精品久久久久久国模美 | 久久天天躁狠狠躁夜夜免费观看 | 国产综合久久久久鬼色 | 天堂а√在线中文在线 | 一本大道伊人av久久综合 | 国产成人午夜福利在线播放 | 蜜桃视频韩日免费播放 | 中文字幕+乱码+中文字幕一区 | 国产成人一区二区三区在线观看 | 欧美日本免费一区二区三区 | 国产精品视频免费播放 | 久久久精品欧美一区二区免费 | 精品欧洲av无码一区二区三区 | 久久久久亚洲精品中文字幕 | 欧美日韩视频无码一区二区三 | 欧美 日韩 亚洲 在线 | 久久婷婷五月综合色国产香蕉 | 四虎影视成人永久免费观看视频 | 最近的中文字幕在线看视频 | 国产一区二区三区日韩精品 | 国产人妻人伦精品1国产丝袜 | 欧美人与牲动交xxxx | 久久综合香蕉国产蜜臀av | 国产精品丝袜黑色高跟鞋 | 99久久人妻精品免费一区 | 欧美日韩精品 | 日日麻批免费40分钟无码 | 日韩精品无码一区二区中文字幕 | 少妇无码av无码专区在线观看 | 国产人妖乱国产精品人妖 | 国产亚洲精品久久久久久大师 | 成人三级无码视频在线观看 | 99久久99久久免费精品蜜桃 | 人人妻人人澡人人爽欧美一区 | 国产乱人无码伦av在线a | 成人aaa片一区国产精品 | 熟妇激情内射com | 国产熟女一区二区三区四区五区 | 亚洲熟妇色xxxxx欧美老妇 | 亚洲成av人片在线观看无码不卡 | a片免费视频在线观看 | 色综合久久网 | 天干天干啦夜天干天2017 | 色婷婷综合激情综在线播放 | 久久久精品国产sm最大网站 | 亚洲日韩av一区二区三区中文 | 亚洲精品欧美二区三区中文字幕 | √8天堂资源地址中文在线 | 久久久久久久女国产乱让韩 | 中文字幕无码免费久久9一区9 | 中文字幕人妻无码一夲道 | av无码久久久久不卡免费网站 | 中文字幕 亚洲精品 第1页 | 国产人妖乱国产精品人妖 | 日本又色又爽又黄的a片18禁 | 国产亚洲精品久久久闺蜜 | 亚洲熟妇色xxxxx亚洲 | 欧美老人巨大xxxx做受 | 人人妻人人澡人人爽人人精品 | 国模大胆一区二区三区 | 九月婷婷人人澡人人添人人爽 | 中文字幕人妻丝袜二区 | 亚洲综合精品香蕉久久网 | 蜜桃视频韩日免费播放 | 日韩精品无码一本二本三本色 | 日韩亚洲欧美中文高清在线 | 亚洲爆乳大丰满无码专区 | 国产无遮挡吃胸膜奶免费看 | 99re在线播放 | 国产农村乱对白刺激视频 | 无人区乱码一区二区三区 | 午夜成人1000部免费视频 | 天天摸天天透天天添 | 97se亚洲精品一区 | 久久久久久久久蜜桃 | 国产农村妇女高潮大叫 | 久久99久久99精品中文字幕 | а√资源新版在线天堂 | 久久97精品久久久久久久不卡 | 久久 国产 尿 小便 嘘嘘 | 成熟妇人a片免费看网站 | 亚洲一区二区三区在线观看网站 | 极品尤物被啪到呻吟喷水 | 国产97人人超碰caoprom | 国产综合在线观看 | 中文无码成人免费视频在线观看 | av小次郎收藏 | 伊人色综合久久天天小片 | 少妇人妻av毛片在线看 | 国产乡下妇女做爰 | 国产一区二区三区日韩精品 | 色诱久久久久综合网ywww | 俺去俺来也在线www色官网 | 成熟人妻av无码专区 | 99久久久无码国产aaa精品 | 亚洲啪av永久无码精品放毛片 | 久久视频在线观看精品 | 亚洲成a人片在线观看无码3d | 日韩精品乱码av一区二区 | 人人澡人人妻人人爽人人蜜桃 | 国产人妖乱国产精品人妖 | 无遮无挡爽爽免费视频 | 秋霞特色aa大片 | 国产精品二区一区二区aⅴ污介绍 | 国产黑色丝袜在线播放 | 免费观看黄网站 | 又大又黄又粗又爽的免费视频 | 亚洲小说春色综合另类 | 国产超碰人人爽人人做人人添 | 四虎影视成人永久免费观看视频 | 欧美性黑人极品hd | 国产成人无码av片在线观看不卡 | 国产xxx69麻豆国语对白 | 亚洲乱亚洲乱妇50p | 久久久久亚洲精品中文字幕 | 成人毛片一区二区 | 国产绳艺sm调教室论坛 | 夫妻免费无码v看片 | 澳门永久av免费网站 | 亚洲一区二区三区偷拍女厕 | 欧美猛少妇色xxxxx | 强伦人妻一区二区三区视频18 | 夜夜夜高潮夜夜爽夜夜爰爰 | 国内精品一区二区三区不卡 | 宝宝好涨水快流出来免费视频 | 亚洲经典千人经典日产 | www一区二区www免费 | 人人妻人人澡人人爽人人精品浪潮 | 大肉大捧一进一出视频出来呀 | 搡女人真爽免费视频大全 | 18无码粉嫩小泬无套在线观看 | 免费无码午夜福利片69 | 久热国产vs视频在线观看 | 久久天天躁狠狠躁夜夜免费观看 | 久久人人97超碰a片精品 | 国产午夜无码精品免费看 | 精品无码一区二区三区爱欲 | 国产在线aaa片一区二区99 | 国产av人人夜夜澡人人爽麻豆 | 国产成人无码专区 | 欧美日韩人成综合在线播放 | 欧洲vodafone精品性 | 最新版天堂资源中文官网 | 老熟妇仑乱视频一区二区 | 99久久精品国产一区二区蜜芽 | 好屌草这里只有精品 | 国产深夜福利视频在线 | 中文字幕无线码 | 久久人人爽人人人人片 | 色偷偷人人澡人人爽人人模 | 日日碰狠狠丁香久燥 | 亚洲 日韩 欧美 成人 在线观看 | 99riav国产精品视频 | 综合人妻久久一区二区精品 | 国产精品久久久久久无码 | 无码帝国www无码专区色综合 | 亚洲欧洲中文日韩av乱码 | 国产超碰人人爽人人做人人添 | 日韩精品无码免费一区二区三区 | 鲁一鲁av2019在线 | 日日摸夜夜摸狠狠摸婷婷 | 国产成人无码一二三区视频 | 成人一区二区免费视频 | 麻豆蜜桃av蜜臀av色欲av | 欧美三级不卡在线观看 | 欧美老人巨大xxxx做受 | 又大又硬又黄的免费视频 | 高潮毛片无遮挡高清免费 | 成人精品天堂一区二区三区 | 小泽玛莉亚一区二区视频在线 | 丰满护士巨好爽好大乳 | 久久人人97超碰a片精品 | 一本久道高清无码视频 | 精品国偷自产在线视频 | 55夜色66夜色国产精品视频 | 国产一区二区三区日韩精品 | 99久久精品日本一区二区免费 | 日韩无套无码精品 | 亚洲第一无码av无码专区 | 午夜性刺激在线视频免费 | 国精产品一区二区三区 | 人妻尝试又大又粗久久 | 色综合久久中文娱乐网 | 国产真实乱对白精彩久久 | 国产无套内射久久久国产 | 日日天日日夜日日摸 | 国产成人精品一区二区在线小狼 | 精品无人区无码乱码毛片国产 | 国产亚洲精品久久久闺蜜 | 久久99国产综合精品 | 国产精品亚洲综合色区韩国 | 免费观看又污又黄的网站 | 精品熟女少妇av免费观看 | 亚洲a无码综合a国产av中文 | 国产精品人妻一区二区三区四 | 99er热精品视频 | 国产两女互慰高潮视频在线观看 | 亚洲精品综合一区二区三区在线 | 亚洲人亚洲人成电影网站色 | 蜜臀av在线播放 久久综合激激的五月天 | 丰腴饱满的极品熟妇 | 精品国产一区二区三区av 性色 | 无码人妻av免费一区二区三区 | 狂野欧美性猛xxxx乱大交 | 精品欧美一区二区三区久久久 | 强伦人妻一区二区三区视频18 | 亚洲一区二区三区含羞草 | 在线a亚洲视频播放在线观看 | 精品人妻人人做人人爽 | 国产又粗又硬又大爽黄老大爷视 | 免费人成网站视频在线观看 | 人妻少妇精品无码专区二区 | 欧美35页视频在线观看 | 欧美精品无码一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 荫蒂添的好舒服视频囗交 | 国产人妻精品一区二区三区不卡 | 国产热a欧美热a在线视频 | 三级4级全黄60分钟 | 99久久人妻精品免费二区 | 亚洲理论电影在线观看 | 人妻体内射精一区二区三四 | 日产精品99久久久久久 | 噜噜噜亚洲色成人网站 | 天天躁夜夜躁狠狠是什么心态 | 欧美 丝袜 自拍 制服 另类 | 久久99精品久久久久久动态图 | 国产成人精品久久亚洲高清不卡 | 97资源共享在线视频 | 水蜜桃色314在线观看 | 日韩av激情在线观看 | 中文字幕av伊人av无码av | 无码人妻av免费一区二区三区 | 美女黄网站人色视频免费国产 | 久久99精品国产麻豆蜜芽 | 久久 国产 尿 小便 嘘嘘 | 啦啦啦www在线观看免费视频 | 日韩人妻无码中文字幕视频 | 日日麻批免费40分钟无码 | 无码吃奶揉捏奶头高潮视频 | 亚洲一区二区三区国产精华液 | 无码乱肉视频免费大全合集 | 天堂а√在线地址中文在线 | 扒开双腿疯狂进出爽爽爽视频 | www国产亚洲精品久久网站 | 亚洲第一无码av无码专区 | 美女黄网站人色视频免费国产 | 捆绑白丝粉色jk震动捧喷白浆 | 久久99久久99精品中文字幕 | 黑人大群体交免费视频 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲精品一区三区三区在线观看 | 免费无码肉片在线观看 | 免费观看黄网站 | 男女下面进入的视频免费午夜 | 无码国模国产在线观看 | www国产亚洲精品久久久日本 | 国产xxx69麻豆国语对白 | 国产香蕉尹人综合在线观看 | 国产成人精品久久亚洲高清不卡 | 无码帝国www无码专区色综合 | 最新国产乱人伦偷精品免费网站 | 亚洲成a人一区二区三区 | 中文亚洲成a人片在线观看 | 国产精品办公室沙发 | 1000部夫妻午夜免费 | 成熟人妻av无码专区 | 亚洲综合伊人久久大杳蕉 | yw尤物av无码国产在线观看 | 青草青草久热国产精品 | 荫蒂被男人添的好舒服爽免费视频 | 久久99国产综合精品 | 欧美肥老太牲交大战 | 久久精品女人的天堂av | 亚洲国产欧美在线成人 | 亚洲精品国产精品乱码视色 | 欧美性色19p | 日韩精品无码一本二本三本色 | 99精品久久毛片a片 | 亚洲中文字幕在线观看 | 久久www免费人成人片 | 国产午夜亚洲精品不卡下载 | 国产av一区二区精品久久凹凸 | 午夜男女很黄的视频 | 熟女少妇人妻中文字幕 | 日韩欧美成人免费观看 | 亚洲s码欧洲m码国产av | 亚洲热妇无码av在线播放 | 久久精品国产亚洲精品 | √天堂中文官网8在线 | 久久99精品国产.久久久久 | 大屁股大乳丰满人妻 | 欧美人与动性行为视频 | 啦啦啦www在线观看免费视频 | 国产av剧情md精品麻豆 | 香港三级日本三级妇三级 | 欧美人与禽猛交狂配 | 亚洲 高清 成人 动漫 | 极品尤物被啪到呻吟喷水 | 亚洲色在线无码国产精品不卡 | 亚洲欧美中文字幕5发布 | 18无码粉嫩小泬无套在线观看 | 欧美人与物videos另类 | 国产网红无码精品视频 | 无遮无挡爽爽免费视频 | 日本一本二本三区免费 | 99久久精品午夜一区二区 | 成人精品视频一区二区 | 色 综合 欧美 亚洲 国产 | 牲欲强的熟妇农村老妇女视频 | 亚洲国产精品成人久久蜜臀 | 国内揄拍国内精品人妻 | 成人免费无码大片a毛片 | 东京无码熟妇人妻av在线网址 | 国产精品18久久久久久麻辣 | 黄网在线观看免费网站 | 久久伊人色av天堂九九小黄鸭 | 妺妺窝人体色www在线小说 | 亚洲国产高清在线观看视频 | 亚洲国产日韩a在线播放 | 男人扒开女人内裤强吻桶进去 | 国产精品美女久久久网av | 免费国产成人高清在线观看网站 | 国产绳艺sm调教室论坛 | 国产sm调教视频在线观看 | 熟妇人妻激情偷爽文 | 成人无码精品一区二区三区 | 亚洲爆乳精品无码一区二区三区 | 欧美一区二区三区视频在线观看 | 999久久久国产精品消防器材 | 精品无码av一区二区三区 | 99国产精品白浆在线观看免费 | 东京热无码av男人的天堂 | 亚洲中文字幕av在天堂 | 久久久中文久久久无码 | 亚洲一区二区三区偷拍女厕 | 亚洲男人av香蕉爽爽爽爽 | 人妻互换免费中文字幕 | 俺去俺来也在线www色官网 | 蜜臀av无码人妻精品 | 永久免费精品精品永久-夜色 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 88国产精品欧美一区二区三区 | 国产色在线 | 国产 | 欧美激情内射喷水高潮 | 亚洲精品一区二区三区四区五区 | 精品国产成人一区二区三区 | 亚洲性无码av中文字幕 | 欧美黑人巨大xxxxx | 国产亚洲精品久久久久久久 | 欧洲极品少妇 | 一本大道伊人av久久综合 | 少妇被黑人到高潮喷出白浆 | 色综合久久久久综合一本到桃花网 | 国产精品美女久久久久av爽李琼 | 亚洲精品一区二区三区婷婷月 | 色婷婷av一区二区三区之红樱桃 | 色婷婷欧美在线播放内射 | 久久亚洲中文字幕无码 | 亚洲综合精品香蕉久久网 | 欧美zoozzooz性欧美 | 亚洲伊人久久精品影院 | 亚洲阿v天堂在线 | 亚洲午夜福利在线观看 | 亚洲自偷自拍另类第1页 | 久青草影院在线观看国产 | 久久婷婷五月综合色国产香蕉 | 久久国产自偷自偷免费一区调 | 熟女体下毛毛黑森林 | 131美女爱做视频 | 亚洲 欧美 激情 小说 另类 | 无码免费一区二区三区 | 免费无码肉片在线观看 | 久久精品国产一区二区三区肥胖 | 亚欧洲精品在线视频免费观看 | 国内综合精品午夜久久资源 | 国产激情无码一区二区app | 国产精品第一国产精品 | 国产人妻精品一区二区三区不卡 | 无码乱肉视频免费大全合集 | 亚洲精品国产精品乱码视色 | 亚洲精品国产精品乱码视色 | 久久午夜夜伦鲁鲁片无码免费 | 国内少妇偷人精品视频免费 | 久久精品女人天堂av免费观看 | 国产人妻久久精品二区三区老狼 | 欧美午夜特黄aaaaaa片 | 亚洲码国产精品高潮在线 | 国产人妖乱国产精品人妖 | 久在线观看福利视频 | 99riav国产精品视频 | 日韩人妻无码一区二区三区久久99 | 精品国偷自产在线视频 | 人人妻人人藻人人爽欧美一区 | 妺妺窝人体色www在线小说 | 亚洲自偷自偷在线制服 | 少妇人妻av毛片在线看 | 久久久久se色偷偷亚洲精品av | 欧美亚洲日韩国产人成在线播放 | 亚洲成色在线综合网站 | 成人av无码一区二区三区 | 日本免费一区二区三区最新 | 亚洲精品鲁一鲁一区二区三区 | 亚洲欧美综合区丁香五月小说 | 99久久久无码国产aaa精品 | 久久久久国色av免费观看性色 | 高中生自慰www网站 | 女人被爽到呻吟gif动态图视看 | 老熟女重囗味hdxx69 | 国产成人精品久久亚洲高清不卡 | 亚洲 另类 在线 欧美 制服 | 日本护士毛茸茸高潮 | 欧洲熟妇色 欧美 | 377p欧洲日本亚洲大胆 | aⅴ在线视频男人的天堂 | 中文字幕色婷婷在线视频 | 欧美人妻一区二区三区 | 日本又色又爽又黄的a片18禁 | 国产深夜福利视频在线 | 国色天香社区在线视频 | 欧美自拍另类欧美综合图片区 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 丰满妇女强制高潮18xxxx | 国产成人精品三级麻豆 | 亚洲 激情 小说 另类 欧美 | 国产激情一区二区三区 | 国产精品久久久久9999小说 | 99精品视频在线观看免费 | 欧美xxxxx精品 | 国产成人无码a区在线观看视频app | 亚洲 a v无 码免 费 成 人 a v | 一本久久a久久精品亚洲 | 熟女少妇人妻中文字幕 | 天海翼激烈高潮到腰振不止 | 亚洲日韩av片在线观看 | 天天综合网天天综合色 | 久久综合色之久久综合 | 国产精品无套呻吟在线 | 亚洲国产日韩a在线播放 | 国产国语老龄妇女a片 | 精品人妻人人做人人爽夜夜爽 | 国产精品久久久久无码av色戒 | 亚洲国产日韩a在线播放 | 无码免费一区二区三区 | 丰满肥臀大屁股熟妇激情视频 | 澳门永久av免费网站 | 国产熟妇高潮叫床视频播放 | 中文字幕人妻无码一区二区三区 | 午夜嘿嘿嘿影院 | 免费国产成人高清在线观看网站 | 国产美女精品一区二区三区 | 久久 国产 尿 小便 嘘嘘 | 网友自拍区视频精品 | www国产亚洲精品久久久日本 | 亚洲 高清 成人 动漫 | 久久人人爽人人爽人人片av高清 | 在线天堂新版最新版在线8 | 日本精品高清一区二区 | 无码人妻久久一区二区三区不卡 | 久久伊人色av天堂九九小黄鸭 | 日本精品高清一区二区 | 国产精品无码一区二区三区不卡 | 欧美日韩亚洲国产精品 | 熟女体下毛毛黑森林 | 欧美xxxx黑人又粗又长 | 九九综合va免费看 | 国产人妻大战黑人第1集 | 久久久久国色av免费观看性色 | av在线亚洲欧洲日产一区二区 | 综合激情五月综合激情五月激情1 | 中文字幕人妻无码一区二区三区 | 伊在人天堂亚洲香蕉精品区 | 国产另类ts人妖一区二区 | 人妻人人添人妻人人爱 | 一本久久a久久精品亚洲 | 日本在线高清不卡免费播放 | 亚洲日韩av一区二区三区中文 | 欧美高清在线精品一区 | 正在播放东北夫妻内射 | 一二三四社区在线中文视频 | 无码午夜成人1000部免费视频 | 暴力强奷在线播放无码 | 娇妻被黑人粗大高潮白浆 | 理论片87福利理论电影 | 国产乱人伦偷精品视频 | 日韩人妻无码中文字幕视频 | 1000部啪啪未满十八勿入下载 | 国产免费久久精品国产传媒 | 成人欧美一区二区三区黑人免费 | 亚洲国产精品久久人人爱 | 午夜福利试看120秒体验区 | 免费国产黄网站在线观看 | 亚洲国产成人av在线观看 | 99麻豆久久久国产精品免费 | 给我免费的视频在线观看 | 最新国产麻豆aⅴ精品无码 | 在线观看欧美一区二区三区 | 久久婷婷五月综合色国产香蕉 | 精品国偷自产在线视频 | 亚洲国产精品一区二区美利坚 | 国产莉萝无码av在线播放 | 一本久道久久综合狠狠爱 | 久久无码专区国产精品s | 亚洲一区二区观看播放 | 国产精品美女久久久久av爽李琼 | 最近中文2019字幕第二页 | 国产av一区二区精品久久凹凸 | 日韩欧美中文字幕公布 | 亚洲日韩av一区二区三区中文 | 成人无码精品一区二区三区 | 丰腴饱满的极品熟妇 | 中文字幕中文有码在线 | 久久综合网欧美色妞网 | 亚洲色无码一区二区三区 | 成人三级无码视频在线观看 | 精品国偷自产在线视频 | 欧美zoozzooz性欧美 | 日韩欧美中文字幕在线三区 | 最新版天堂资源中文官网 | 成人片黄网站色大片免费观看 | 国产成人精品视频ⅴa片软件竹菊 | 日本在线高清不卡免费播放 | 亚洲一区二区三区 | 国产精品手机免费 | 四虎国产精品一区二区 | 日本爽爽爽爽爽爽在线观看免 | 亚洲一区av无码专区在线观看 | 国产精品无套呻吟在线 | 天下第一社区视频www日本 | 欧美日韩视频无码一区二区三 | 免费观看黄网站 | 国产精品多人p群无码 | 久久久久99精品国产片 | 午夜时刻免费入口 | 久久久久人妻一区精品色欧美 | 国产成人一区二区三区在线观看 | 亚洲理论电影在线观看 | 无码国模国产在线观看 | 中文精品无码中文字幕无码专区 | 亚洲码国产精品高潮在线 | 亚洲精品国偷拍自产在线观看蜜桃 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 97人妻精品一区二区三区 | 岛国片人妻三上悠亚 | 一二三四社区在线中文视频 | 国产精品美女久久久网av | 图片区 小说区 区 亚洲五月 | 久在线观看福利视频 | 未满成年国产在线观看 | 精品aⅴ一区二区三区 | 日韩人妻无码中文字幕视频 | 无码人妻久久一区二区三区不卡 | 日本精品久久久久中文字幕 | 东京热无码av男人的天堂 | 国产精品.xx视频.xxtv | 国产网红无码精品视频 | 日本护士xxxxhd少妇 | 人妻体内射精一区二区三四 | 99久久99久久免费精品蜜桃 | 久久久久亚洲精品男人的天堂 | 欧美日韩精品 | 久久国产精品_国产精品 | 久久久久免费看成人影片 | 午夜精品一区二区三区在线观看 | 亚洲欧洲中文日韩av乱码 | 东京热无码av男人的天堂 | 国产卡一卡二卡三 | 亚洲欧美中文字幕5发布 | 欧美国产日韩亚洲中文 | 无码乱肉视频免费大全合集 | 国产精品丝袜黑色高跟鞋 | 久久综合九色综合欧美狠狠 | 强奷人妻日本中文字幕 | 中文字幕+乱码+中文字幕一区 | 久久久成人毛片无码 | 国产后入清纯学生妹 | a片免费视频在线观看 | 狠狠色噜噜狠狠狠7777奇米 | 日本护士xxxxhd少妇 | 无码精品国产va在线观看dvd | 一本久道高清无码视频 | 国产亚洲精品久久久久久久 | 女人被男人躁得好爽免费视频 | 成人无码精品一区二区三区 | 免费播放一区二区三区 | 国产成人精品优优av | 亚洲自偷精品视频自拍 | 亚洲国产精品无码一区二区三区 | 欧美精品无码一区二区三区 | 99国产精品白浆在线观看免费 | 亚洲人成网站色7799 | 大胆欧美熟妇xx | 丰满少妇女裸体bbw | 一本久久伊人热热精品中文字幕 | 妺妺窝人体色www在线小说 | 性欧美牲交在线视频 | 亚洲精品久久久久avwww潮水 | 欧美亚洲国产一区二区三区 | 国产色视频一区二区三区 | 国产国产精品人在线视 | 亚洲色偷偷偷综合网 | 国产婷婷色一区二区三区在线 | 亚洲一区二区三区播放 | 久久亚洲日韩精品一区二区三区 | 狠狠色欧美亚洲狠狠色www | 亚洲色大成网站www | 亚洲成a人片在线观看无码 | 一区二区三区乱码在线 | 欧洲 | 久久精品女人天堂av免费观看 | 亚洲欧洲无卡二区视頻 | 无码吃奶揉捏奶头高潮视频 | 色综合久久久无码中文字幕 | 亚洲人亚洲人成电影网站色 | 水蜜桃亚洲一二三四在线 | 国产另类ts人妖一区二区 | 亚洲另类伦春色综合小说 | 精品乱码久久久久久久 | 久久亚洲精品中文字幕无男同 | 色综合久久88色综合天天 | 久久精品视频在线看15 | 日韩精品无码免费一区二区三区 | 天天躁日日躁狠狠躁免费麻豆 | 久久久久99精品成人片 | 成熟妇人a片免费看网站 | 一本久道久久综合狠狠爱 | av无码不卡在线观看免费 | 久久国语露脸国产精品电影 | 野外少妇愉情中文字幕 | 久久亚洲中文字幕无码 | 少妇性俱乐部纵欲狂欢电影 | 国产av久久久久精东av | aⅴ亚洲 日韩 色 图网站 播放 | 国产成人精品视频ⅴa片软件竹菊 | 国精产品一品二品国精品69xx | 欧美精品免费观看二区 | 亚洲一区二区观看播放 | 日本精品人妻无码免费大全 | 十八禁真人啪啪免费网站 | 亚洲精品国产第一综合99久久 | 国产真实夫妇视频 | 久久熟妇人妻午夜寂寞影院 | 久久人人97超碰a片精品 | 国产精品久久福利网站 | 少妇激情av一区二区 | 亚洲精品无码国产 | 激情人妻另类人妻伦 | 亚洲男女内射在线播放 | 影音先锋中文字幕无码 | 欧美人与禽zoz0性伦交 | 欧洲精品码一区二区三区免费看 | 亚洲精品国产a久久久久久 | 男人扒开女人内裤强吻桶进去 | 亚洲精品国产品国语在线观看 | 最新国产乱人伦偷精品免费网站 | 精品水蜜桃久久久久久久 | 四虎永久在线精品免费网址 | 亚洲大尺度无码无码专区 | 伊人久久大香线蕉av一区二区 | 成人无码精品一区二区三区 | 领导边摸边吃奶边做爽在线观看 | 日韩人妻少妇一区二区三区 | 亚洲精品成a人在线观看 | 无码人妻丰满熟妇区五十路百度 | 久久精品无码一区二区三区 | 精品少妇爆乳无码av无码专区 | 亚洲国产日韩a在线播放 | 无码播放一区二区三区 | 亚洲欧美综合区丁香五月小说 | 无码av中文字幕免费放 | 国产精品a成v人在线播放 | 亚洲国产高清在线观看视频 | 亚洲成a人一区二区三区 | 久9re热视频这里只有精品 | 在教室伦流澡到高潮hnp视频 | 在线视频网站www色 | 亚洲乱码日产精品bd | 精品欧美一区二区三区久久久 | 奇米影视7777久久精品人人爽 | a国产一区二区免费入口 | 免费国产成人高清在线观看网站 | 久久精品女人的天堂av | 爆乳一区二区三区无码 | 熟妇人妻无乱码中文字幕 | 免费男性肉肉影院 | 又紧又大又爽精品一区二区 | 波多野结衣av在线观看 | 亚洲男人av香蕉爽爽爽爽 | 亚洲色无码一区二区三区 | 国产av无码专区亚洲awww | 欧美人与禽猛交狂配 | 色婷婷欧美在线播放内射 | 亚洲男人av香蕉爽爽爽爽 | 四虎国产精品一区二区 | 内射爽无广熟女亚洲 | 精品 日韩 国产 欧美 视频 | 玩弄少妇高潮ⅹxxxyw | 天天av天天av天天透 | 俄罗斯老熟妇色xxxx | 亚洲综合精品香蕉久久网 | 激情亚洲一区国产精品 | 国产一区二区三区日韩精品 | 久久久久国色av免费观看性色 | 天干天干啦夜天干天2017 | 国产精品久久久久久亚洲毛片 | 免费观看激色视频网站 | 免费国产成人高清在线观看网站 | 免费人成在线视频无码 | 亚洲成av人综合在线观看 | 色老头在线一区二区三区 | 亚洲精品国产第一综合99久久 | 波多野结衣一区二区三区av免费 | 国产精品久久久av久久久 | 成在人线av无码免观看麻豆 | 久久人人爽人人爽人人片ⅴ | 亚洲中文字幕久久无码 | 99久久无码一区人妻 | 国产精品无码mv在线观看 | 国产69精品久久久久app下载 | 日本又色又爽又黄的a片18禁 | 国产午夜无码视频在线观看 | 人妻无码αv中文字幕久久琪琪布 | 中文字幕人妻丝袜二区 | 老子影院午夜精品无码 | 成在人线av无码免观看麻豆 | 色欲av亚洲一区无码少妇 | 人人妻人人藻人人爽欧美一区 | 无码成人精品区在线观看 | 丝袜美腿亚洲一区二区 | 国产精品免费大片 | 精品少妇爆乳无码av无码专区 | 欧美丰满熟妇xxxx性ppx人交 | 日本大香伊一区二区三区 | www国产精品内射老师 | 图片区 小说区 区 亚洲五月 | 国产成人亚洲综合无码 | 波多野结衣aⅴ在线 | 亚洲中文字幕av在天堂 | 天天摸天天碰天天添 | 午夜精品一区二区三区的区别 | 天堂а√在线地址中文在线 | 久久精品一区二区三区四区 | 亚洲精品美女久久久久久久 | 亚洲区小说区激情区图片区 | 亚洲精品国产第一综合99久久 | 香港三级日本三级妇三级 | 呦交小u女精品视频 | 人人爽人人爽人人片av亚洲 | 九月婷婷人人澡人人添人人爽 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 久久久精品成人免费观看 | 成人亚洲精品久久久久软件 | 亚洲午夜福利在线观看 | 乱人伦人妻中文字幕无码 | 久久久精品456亚洲影院 | 99久久人妻精品免费一区 | 成人精品视频一区二区 | 日韩欧美中文字幕在线三区 | 亚洲精品一区二区三区婷婷月 | 亚洲乱码中文字幕在线 | 夜夜躁日日躁狠狠久久av | 女人高潮内射99精品 | 欧美激情一区二区三区成人 | 久久99精品久久久久婷婷 | 99久久精品日本一区二区免费 | 欧美激情综合亚洲一二区 | 天天摸天天碰天天添 | 亚洲中文字幕无码中文字在线 | 一本久道久久综合狠狠爱 | 日本大乳高潮视频在线观看 | 亚洲中文字幕乱码av波多ji | 久久精品99久久香蕉国产色戒 | 国产精品高潮呻吟av久久 | 午夜福利电影 | 亚洲第一网站男人都懂 | 搡女人真爽免费视频大全 | 无码人妻丰满熟妇区五十路百度 | 欧洲熟妇色 欧美 | 久久久久亚洲精品中文字幕 | 亚洲精品午夜无码电影网 | 精品国精品国产自在久国产87 | 国产无遮挡又黄又爽免费视频 | 国产人妖乱国产精品人妖 | 精品成在人线av无码免费看 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 99精品无人区乱码1区2区3区 | 女人被男人躁得好爽免费视频 | 中文字幕乱码人妻二区三区 | 亚洲天堂2017无码 | 久久人人爽人人人人片 | 性生交大片免费看女人按摩摩 | 久9re热视频这里只有精品 | 熟妇人妻中文av无码 | 国内精品一区二区三区不卡 | 无码av最新清无码专区吞精 | 天堂а√在线中文在线 | 亚洲精品国产第一综合99久久 | 亚洲爆乳无码专区 | 狠狠色色综合网站 | 全球成人中文在线 | 国产97色在线 | 免 | 免费无码午夜福利片69 | 国产精品久久福利网站 | 免费观看黄网站 | 欧美黑人性暴力猛交喷水 | 色综合久久久久综合一本到桃花网 | 国产激情一区二区三区 | 国内少妇偷人精品视频 | 双乳奶水饱满少妇呻吟 | 久久国产精品偷任你爽任你 | 欧美人与牲动交xxxx | 日韩 欧美 动漫 国产 制服 | 中文精品久久久久人妻不卡 | 国产成人综合色在线观看网站 | 日韩无码专区 | 国产亲子乱弄免费视频 | 丰满人妻一区二区三区免费视频 | 天堂一区人妻无码 | 粗大的内捧猛烈进出视频 | 女人被爽到呻吟gif动态图视看 | 学生妹亚洲一区二区 | 国产午夜无码精品免费看 | 中文字幕色婷婷在线视频 | 蜜桃av抽搐高潮一区二区 | 日本成熟视频免费视频 | 天天拍夜夜添久久精品 | 亚洲区欧美区综合区自拍区 | a在线观看免费网站大全 | 玩弄人妻少妇500系列视频 | 自拍偷自拍亚洲精品10p | 中文字幕日韩精品一区二区三区 | 乱人伦中文视频在线观看 | 老头边吃奶边弄进去呻吟 | 牲欲强的熟妇农村老妇女 | 久久亚洲精品成人无码 | 精品国产一区二区三区av 性色 | 宝宝好涨水快流出来免费视频 | 成人三级无码视频在线观看 | 亚洲熟悉妇女xxx妇女av | 国产内射爽爽大片视频社区在线 | 99久久婷婷国产综合精品青草免费 | 老子影院午夜伦不卡 | 久9re热视频这里只有精品 | 国产亚洲日韩欧美另类第八页 | 初尝人妻少妇中文字幕 | 色偷偷人人澡人人爽人人模 | 永久免费观看美女裸体的网站 | 欧美亚洲日韩国产人成在线播放 | 丰满人妻精品国产99aⅴ | 久久久av男人的天堂 | 久久无码人妻影院 | 亚洲娇小与黑人巨大交 | 亚洲天堂2017无码 | 激情爆乳一区二区三区 | 久久亚洲中文字幕精品一区 | 色老头在线一区二区三区 | 国产精品18久久久久久麻辣 | 伊人色综合久久天天小片 | 久久人人爽人人爽人人片av高清 | 成人片黄网站色大片免费观看 | 狠狠噜狠狠狠狠丁香五月 | 亚洲日本va午夜在线电影 | 青草青草久热国产精品 | 午夜无码区在线观看 | 国产精品成人av在线观看 | 牲欲强的熟妇农村老妇女视频 | 亚洲a无码综合a国产av中文 | 久久精品国产日本波多野结衣 | 色欲人妻aaaaaaa无码 | 精品国产麻豆免费人成网站 | 中文字幕日产无线码一区 | 好爽又高潮了毛片免费下载 | 亚洲日韩一区二区三区 | 国产av一区二区三区最新精品 | 奇米影视888欧美在线观看 | 妺妺窝人体色www在线小说 | 国产亚av手机在线观看 | 高清不卡一区二区三区 | 青青草原综合久久大伊人精品 | 麻豆国产人妻欲求不满 | 国产成人综合在线女婷五月99播放 | 久久综合久久自在自线精品自 | 国产无av码在线观看 | 亚洲综合无码久久精品综合 | 国产亚洲精品久久久久久 | 久青草影院在线观看国产 | 国产成人精品久久亚洲高清不卡 | 国产艳妇av在线观看果冻传媒 | 精品无人区无码乱码毛片国产 | 国产熟妇另类久久久久 | 国产精品久久久久影院嫩草 | 午夜无码人妻av大片色欲 | 无码成人精品区在线观看 | 无码免费一区二区三区 | 国产精品手机免费 | 亚洲日本在线电影 | 亚洲中文字幕无码中字 | 久久久久99精品成人片 | 国产手机在线αⅴ片无码观看 | 亚洲 欧美 激情 小说 另类 | 国产精品igao视频网 | 十八禁真人啪啪免费网站 | 99久久久无码国产精品免费 | 国产综合久久久久鬼色 | 四虎4hu永久免费 | а天堂中文在线官网 | 国产亚洲精品久久久久久 | 久久综合色之久久综合 | 美女扒开屁股让男人桶 | 3d动漫精品啪啪一区二区中 | 亚洲色欲色欲天天天www | 人妻与老人中文字幕 | 欧美野外疯狂做受xxxx高潮 | 99riav国产精品视频 | 日韩精品乱码av一区二区 | 精品久久8x国产免费观看 | 少妇高潮一区二区三区99 | 国产精品无码一区二区桃花视频 | 亚洲精品国偷拍自产在线麻豆 | 国产69精品久久久久app下载 | 国产激情无码一区二区 | 亚洲s码欧洲m码国产av | 国产美女精品一区二区三区 | 国产精品无码一区二区桃花视频 | 午夜性刺激在线视频免费 | 成 人 网 站国产免费观看 | 青青青爽视频在线观看 | 欧美成人家庭影院 | 亚洲午夜福利在线观看 | www国产亚洲精品久久久日本 | 国产精品久久久av久久久 | 窝窝午夜理论片影院 | 狠狠色欧美亚洲狠狠色www | 一二三四在线观看免费视频 | 高清国产亚洲精品自在久久 | 国产欧美精品一区二区三区 | 久久久久亚洲精品男人的天堂 | 精品国偷自产在线视频 | 日本丰满熟妇videos | 天堂一区人妻无码 | 亚洲性无码av中文字幕 | 高清不卡一区二区三区 | 荫蒂被男人添的好舒服爽免费视频 | 亚洲精品久久久久久久久久久 | 日本熟妇人妻xxxxx人hd | 国产成人综合色在线观看网站 | 色综合久久中文娱乐网 | 国产精品内射视频免费 | 色老头在线一区二区三区 | 国产精品自产拍在线观看 | 久久视频在线观看精品 | 日韩人妻无码中文字幕视频 | 久久人妻内射无码一区三区 | 欧美人与禽猛交狂配 | 日本饥渴人妻欲求不满 | 夜夜躁日日躁狠狠久久av | 国产做国产爱免费视频 | 在线精品亚洲一区二区 | 亚洲精品久久久久久久久久久 | 亚洲国产日韩a在线播放 | 亚洲欧美日韩成人高清在线一区 | 精品久久久中文字幕人妻 | 国产舌乚八伦偷品w中 | 亚洲 欧美 激情 小说 另类 | 中文字幕中文有码在线 | 欧洲vodafone精品性 | 亚洲精品一区二区三区大桥未久 | 两性色午夜免费视频 | 内射巨臀欧美在线视频 | 麻豆md0077饥渴少妇 | 久久亚洲国产成人精品性色 | 少妇久久久久久人妻无码 | 精品久久8x国产免费观看 | 熟妇人妻无乱码中文字幕 | 国产精品久久福利网站 | 成人片黄网站色大片免费观看 | 乱中年女人伦av三区 | 精品无码av一区二区三区 | 少妇性荡欲午夜性开放视频剧场 | 亚洲午夜无码久久 | 真人与拘做受免费视频一 | 国精产品一品二品国精品69xx | 熟妇人妻无乱码中文字幕 | 97色伦图片97综合影院 | 久久人人爽人人爽人人片ⅴ | 国产精品资源一区二区 | 麻豆国产人妻欲求不满谁演的 |