欧美三区四区_av先锋影音资源站_亚洲第一论坛sis_影音先锋2020色资源网_亚洲精品社区_在线免费观看av网站_国产一区二区伦理_亚洲欧美视频一区二区_99视频精品全部免费在线_精精国产xxxx视频在线

adapter和facade模式在Ajax中的應用_AJAX教程

編輯Tag賺U幣
教程Tag:暫無Tag,歡迎添加,賺取U幣!

推薦:AJAX編程實踐之與服務器通信
  首先看下看下相對簡單些的--向服務器發送一個包含有名/值對的簡單查詢串,在這種情況下XHP即可以用GET也可以用POST。 GETfunction doRequestUsingGET() { createXMLHttpRequest(); v

  一、起因

  在看《Ajax in action》的時候,看到它在介紹Adapter和Facade兩種模式。由于目前Web開發的特色,特別是客戶端Js腳本的開發,需要面對很多的變化和跨平臺的挑戰,所以,如果應用Adapter和Facade模式,將會非常有益于提高我們軟件的可維護性,以及降低總體開發成本。

  二、什么是Adapter和Facade模式

  1、Adapter模式

  1.1、定義:

  The Adapter Pattern converts the interface of a class into another interface the clients expect. Adapter lets classes work together that couldn't otherwise because of incompatible interfaces.

  1.2、解釋:

  Adapter模式所要解決的問題,就是接口不一致的問題。在實際的應用程序中,有的時候客戶端(這里指調用方)想要調用的接口與實際上服務端(這里指被調用方)所提供的接口不一致。出現這種情況,我們可能會有兩種選擇,一種是修改調用方或者被調用方的接口,使之互相適應。另一種就是在調用方和被調用方之間加入一個Adapter,用其連接調用方和被調用方。

  在Adapter模式里,Adapter所起的作用,就是一個接口適配器。一個Adapter類會實現(implements)調用方所期待的接口,并且在類中通過委派(delegate)來調用被調用方,從而實現兩種不同接口的連接。

  1.3、分類:

  Adapter模式分為兩種實現方式,一種是對象適配器(Object Adapters)和類適配器(Class Adapters)。其中對象適配器(Object Adapters)通過組合(composition)實現,而類適配器(Class Adapters)通過多繼承實現。

  1.4、關鍵點:

  模式的關鍵點在于其意圖。Adapter模式的意圖很明顯,就是為了使兩個彼此不兼容的接口兼容,使一個本來并不是調用方所期待的接口看起來跟所期待的一樣。

  在《Head.First.Design.Patterns》這本書里,有一句話可以非常完美并且有趣的描述Adapter模式:

  If it walks like a duck and quacks like a duck, then it might be a turkey wrapped with a duck adapter...

  2、Facade模式

  2.1、定義:

The Facade Pattern provides a unified interface to a set of interfaces in subsystem. Facade defines a higher-level interface that makes the subsystem easier to use.

  2.2、解釋:

  Facade模式的意圖也是非常明顯。有時候,我們的客戶端(調用方)所調用的子系統(subsystem,被調用方)過于復雜。通常,調用方需要連續調用被調用方的N個接口才能完成某種特定的任務。每次調用方重復調用操作都非常繁瑣,容易出錯,所以本著DRY(Don’t Repeat Yourself)的原則,我們需要提煉出一些經常用到的操作組合成一個接口。這樣,每次調用方執行該功能時,僅需要調用該Facade接口,便可以輕松執行某項特定任務。

  2.3、作用

  Facade模式的作用主要有兩點:

  1、為一個太復雜的子系統(subsystem)提供一個統一的、簡單的接口共調用方使用。通常需要DRY的接口都是使用率非常高,并且比較復雜的接口。將該接口提取出來,有益于簡化工作,并且統一接口名稱。

  2、降低系統的耦合度。一批事物的變化率遠大于一個事物。應用Facade模式的情景,一般是由于子系統太復雜。當調用方需要執行某些任務時,需要執行一連串操作。而隨著子系統的升級,這一連串操作的變化的可能性是非常大的。但是,不管子系統如何變,這一連串操作所提供的功能或者是意義永遠不變。所以,Facade模式有利于降低耦合度。

  2.4、關鍵點:

  Facade模式的關鍵點在于,引入Facade模式主要是為了簡化和統一接口。Facade模式的接口一般是子系統的一個“快捷方式”。調用方如果還有其他的復雜功能的話,依然可以直接調用子系統的其他接口。

  3、Adapter和Facade模式的區別

  模式的區別就在于,要領會其根本的意圖。這里有一句話,描述了Adapter和Facade模式以及Decorator模式(這里可以先不管decorator模式)。

  An adapter wraps an object to change its interface, a decorator wraps an object to add new behaviors and responsibilities, and a facade "wraps" a set of objects to simplify.

  三、Web開發所面臨的問題

  Ajax時代的Web開發,有一個共同的特點。由于此時的瀏覽器端應用再也不是傳統的簡單頁面,而變成了復雜的javascript客戶端應用程序。所以,隨著代碼量的上升,要求我們用更加合乎軟工的方式去看待Ajax應用程序。如果在此時能夠引入各種OO原則及模式,將會提高Ajax應用程序的整體質量。

  目前在瀏覽器端進行javascript開發時,主要會面臨這么兩種問題:

  1、目前的Web開發還比較混亂。各種瀏覽器對W3C標準的支持都有問題,并不統一。進行Web開發時,盡管我們一直提倡基于Web標準進行開發,但有時我們往往有些力不從心。

  2、Web開發過程中所使用的各種瀏覽器API,其本身組合的也并不足夠合理。有時候為了執行某項操作,我們需要連續操作很多接口。而實際上,在大多數情況下,我們都沒必要這么DRY(Do Repeat Yourself).

  你可以看到,其實上面兩種情況就分別對應于設計模式中的Adapter和Façade兩種模式的需求。那么,下面讓我們看看如何在實際的代碼中應用上述兩種模式解決問題?

  四、如何應用Adapter和Facade模式?

  在《Ajax in action》中,同樣有一段代碼,體現了這樣的需求。我把它修改了一下,大家看看,能否從中找出Adapter和Facade模式的影子?

CGIAJAX.util["STATICS"] = {};
CGIAJAX.util.STATICS.READY_STATE_UNINITIALIZED=0;//constant
CGIAJAX.util.STATICS.READY_STATE_LOADING=1;
CGIAJAX.util.STATICS.READY_STATE_LOADED=2;
CGIAJAX.util.STATICS.READY_STATE_INTERACTIVE=3;
CGIAJAX.util.STATICS.READY_STATE_COMPLETE=4;
CGIAJAX.util.ContentLoader = function(url, onload, method, msgBody, onerror)//constructor, contains all attributes
{
this.url=url;
this.onload=onload;
this.method = (method) ? method : "GET";//default value of method is GET
this.msgBody = (msgBody) ? msgBody : null;//default value of message body send to server
this.onerror=(onerror) ? onerror : this.defaultError;//default method to handle error
this.req=null;
}
//contains all method
CGIAJAX.util.ContentLoader.prototype=
{
loadXMLDoc:function()//send request to server to get response
{
if (window.XMLHttpRequest)
{
this.req=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
this.req=new ActiveXObject("Microsoft.XMLHTTP");
}
if (this.req)
{
try
{
var loader=this;
this.req.onreadystatechange=function()
{
loader.onReadyState.call(loader);
}
if ("GET" == this.method)
{
this.req.open('GET',this.url,true);
this.req.send(null);
}
else
{
if (!this.msgBody)
{
this.onerror.call(this);
}
this.req.open(this.method,this.url,true);
this.req.send(this.msgBody);
}
}
catch (err)
{
this.onerror.call(this);
}
}
},
onReadyState:function()
{
var req=this.req;
var ready=req.readyState;
if (ready==CGIAJAX.util.STATICS.READY_STATE_COMPLETE)
{
var httpStatus=req.status;
if (httpStatus==200 || httpStatus==0)
{
this.onload.call(this);
}
else
{
this.onerror.call(this);
}
}
},
defaultError:function()//default error handler
{
alert("error fetching data!"
"\n\nreadyState:" this.req.readyState
"\nstatus: " this.req.status
"\nheaders: " this.req.getAllResponseHeaders());
}
};

  怎么樣,看到了嗎?沒有?那好,讓我來解釋一下這段代碼如何應用Adapter和Facade模式的。當然,這里并不分析具體代碼的含義了。

  1、Adapter模式

  在Ajax應用中經常用到的XHR(xmlHttpRequest)對象,就是需要Adapter模式的一個很好的例子。

  XHR對象非W3C標準,所以,盡管現有的較新的瀏覽器都支持XHR對象,但其具體實現是不一致的。在微軟的IE里,XHR是以“ActiveXObject”的樣式實現的。而在mozilla瀏覽器里,其又以一種build-in對象的形式實現。天知道在其他的什么瀏覽器或者日后的日子里,這種實現方式會不會發生變化。

  而對于我們常用的應用程序來說,我們并不關心這些所有的細節。我們所需要知道的,就是當我們希望創建一個XHR對象時,有一個XHR對象會被創建,并且供我們使用。至于究竟如何創建,我們對它并不關心。所以,你可以看到,在上面的代碼里,我們是通過在ContentLoader類的loadXMLDoc的方法中實現的。

if (window.XMLHttpRequest)
{
this.req=new XMLHttpRequest();
}
else if (window.ActiveXObject)
{
this.req=new ActiveXObject("Microsoft.XMLHTTP");
}

  這里的一個IF語句幫助我們實現了跨平臺性,它便是一個Adapter。在這里,我們通過一點來自動適應各種平臺的變化。我們的程序代碼期待一個統一的創建XHR的接口。這段代碼實現了這個接口,并且通過委托(delegate)的機制,自動幫我們用各種方法在各種不同的平臺下實例化一個XHR對象。

  想象一下,在不遠的未來,有一種Xbrower出現,并且非常紅火,值得我們兼容。我們只要改變我們的Adapter,就可以適應該變化。而我們其他的客戶端代碼都不需要修改,豈不很好嗎?

  2、Facade模式

  當你需要用XHR對象向服務器請求數據的時候,你總是會很痛苦的執行一連串操作,僅僅是為了請求一次數據:

  1、建立XHR對象

  2、注冊callback函數

  3、用open方法設置請求方式,地址,模式

  4、用send發送請求

  5、監視請求的狀態,當達到某一特定狀態時,執行某項特殊功能。。。

  天,好復雜,可是為什么我們要不斷地重復自己呢?

  上面的ContentLoader類就可以很好的屏蔽這些復雜性。當你想要從服務器端獲得一些數據的時候,你關心的是服務器端的數據,而不是這整個復雜的過程。通過應用上面的這個ContentLoader類,你可以很輕松的用兩行代碼就獲得數據。

var myRequest = new CGIAJAX.util.ContentLoader(url, refreshTalbe);
myRequest.loadXMLDoc();

  可以看到,實際上ContentLoader類就是一個簡單的接口,它將整個復雜的接口簡單化、統一化。如此一來,我們就可以DRY了。當然,ContentLoader類并不會使我們的靈活性有所降低。如果你需要的話,你還是可以直接調用瀏覽器所提供的XHR接口的。可是大多數時候,我們只需要用ContentLoader類就可以很好的完成任務了。

  再想象一下。假如說未來W3C將XHR作為標準,并且擴充了XHR接口的功能,那么我們怎么辦?很可能擴充功能的代價就是接口的變化或者接口調用順序的變化。如果我們沒有應用Facade模式,我們會怎樣?逐個修改代碼中每一個用到XHR的地方?知道一切運轉起來看似沒有問題?或者我們現在就應用Facade模式,到時候,我們就可以輕松的修改一下Facade模式所涉及的接口內容,然后跑去看NBA了,不是嗎?

  五、警惕Ajax開發!

  為何要警惕Ajax開發?

  眾所周知,由于Ajax導致Web開發模式上的變化,將會導致客戶端代碼的激增,由量變變成質變。而且最重要的是,Ajax現在所用到的各種技術,很大一部分都還沒有成為標準,或者剛剛成為標準。這就意味著,這些東西會在未來的一段時間內,頻繁變化。如果我們應用程序設計時,對該方面的變化有所準備,那么到頭來痛苦的只有我們自己。

  在Ajax開發中應用OO模式以及OO原則,最重要的并不是炫耀某種技術,而是期望這種已被證明的強大技術能夠為我們的開發帶來根本上的好處。

來源:模板無憂//所屬分類:AJAX教程/更新時間:2008-08-22
相關AJAX教程
无码精品一区二区三区在线| 亚洲精品美女久久7777777| 色哟哟免费视频| 女人18毛片一区二区三区| 在线亚洲国产精品网站| 日韩欧美精品网址| 国产精品吴梦梦| 中文字幕乱码在线人视频| 日本加勒比一区| 美腿丝袜在线亚洲一区| 日韩精品在线看片z| 蜜桃视频在线观看91| 国产又粗又长又硬| 欧美男人操女人视频| 欧美国产97人人爽人人喊| 欧美成人精品一区二区| 97国产精东麻豆人妻电影| 91在线视频国产| 性欧美暴力猛交另类hd| 日韩欧美在线一区二区三区| 欧美日韩国产精品一卡| 中文字幕在线有码| 精品国产乱码| 午夜激情一区二区三区| 成人精品一区二区三区电影免费| 久久无码人妻精品一区二区三区 | 亚洲免费观看在线| 素人啪啪色综合| 99久久伊人久久99| 欧美成人激情视频免费观看| 波多结衣在线观看| 亚洲国产成人二区| 成人午夜视频网站| 久久人人爽人人爽爽久久| 一本久道综合色婷婷五月| 高清毛片aaaaaaaaa片| 理论片日本一区| 亚洲深夜福利在线| 丰满的少妇愉情hd高清果冻传媒| 一级全黄少妇性色生活片| 久久久亚洲一区| 亚洲а∨天堂久久精品喷水| 水蜜桃在线免费观看| 伊人亚洲综合网| 日本不卡的三区四区五区| 亚洲精美色品网站| 日韩精品一区二区在线视频| 国产视频在线观看视频| 极品少妇xxxx精品少妇偷拍 | 欧美国产精品va在线观看| 日韩av卡一卡二| 99精品在免费线偷拍| 国产无人区一区二区三区| 国模私拍视频一区| 国产高潮视频在线观看| 日韩精品一区二区三区中文字幕| 国产精品成人一区二区三区夜夜夜 | 91大片在线观看| avhd101老司机| 国产麻豆精品久久| 欧美日韩精品中文字幕| 精品一区二区三区日本| 久久久久久蜜桃| 合欧美一区二区三区| 日韩欧美国产午夜精品| a级黄色片免费| 高h震动喷水双性1v1| 成人污视频在线观看| 欧美激情视频在线免费观看 欧美视频免费一| 日韩av一卡二卡三卡| 婷婷精品久久久久久久久久不卡| 国产精品欧美久久久久无广告 | 三级久久三级久久| 在线性视频日韩欧美| xxww在线观看| 中文在线免费一区三区| 亚洲综合激情小说| 国语精品中文字幕| 在线观看日本网站| 精彩视频一区二区| 久久久久久久久久婷婷| 中文字幕无码人妻少妇免费| 国产探花一区二区| 欧美美女一区二区三区| 狠狠精品干练久久久无码中文字幕 | 国产成人在线视频观看| 亚洲天堂最新地址| 成人在线免费看视频| 欧美综合二区| 中文字幕亚洲综合久久筱田步美| 国产一区视频免费观看| 日韩毛片免费看| 一区二区三区不卡在线观看| 久久riav| 91女人18毛片水多国产| 成人av资源网站| 国产精品第一视频| 福利所第一导航| 国产精品久久久久久久久久妞妞| 一区二区三区 在线观看视| 亚洲第一天堂久久| 日本亚洲不卡| 91精品国产综合久久福利 | 欧美午夜一区| 亚洲人成电影网| 男人午夜视频在线观看| 无码日韩精品一区二区免费| 欧美久久久影院| 日本日本19xxxⅹhd乱影响| 成人在线视频免费| 亚洲国产成人va在线观看天堂| 欧美韩国日本不卡| 日本一区二区不卡| 午夜国产福利一区二区| 亚洲欧美清纯在线制服| 风间由美性色一区二区三区四区| 欧美激情一区二区三区四区| 成人在线观看91| 久久国产香蕉视频| 国产aⅴ综合色| 国产美女扒开尿口久久久| 偷偷操不一样的久久| 激情综合色播五月| 国产suv精品一区二区| 国产一级理论片| 精品在线一区二区三区| 热99久久精品| 久久久久久久久久久久久久久久久 | 欧美精品momsxxx| 欧美一区二区三区系列电影| 午夜精品久久久内射近拍高清| 亚洲综合伊人| 在线观看国产91| 日本精品一区二区三区四区| 欧美日韩一本| 欧美精品一区二区三区在线播放| 中文字幕在线视频精品| 欧美亚洲国产激情| 亚洲性猛交xxxxwww| 国产乱了高清露脸对白| 亚洲黄色免费| 欧美精品久久久久久久久| 1024手机在线视频| 国产一区二区三区视频在线播放| 国产精品一区二区三区久久久| 精人妻无码一区二区三区| 91蝌蚪国产九色| 久久免费99精品久久久久久| 国产成人无码www免费视频播放| 亚洲另类在线视频| 樱空桃在线播放| 欧美经典影片视频网站| 欧美一二三四区在线| 手机精品视频在线| 欧美黄色一区| 久久91亚洲精品中文字幕奶水| 欧美一级片在线视频| 国产麻豆一精品一av一免费| 亚洲自拍高清视频网站| 国产成人精品免费看视频| 亚洲精品国产第一综合99久久| 久久免费视频2| 伊人精品久久| 精品国产精品网麻豆系列| 国产51自产区| 亚洲精品系列| 国产精品69精品一区二区三区| 久久国产视频一区| 国产午夜亚洲精品羞羞网站| 天天好比中文综合网| 99视频有精品高清视频| 日韩免费视频线观看| youjizz.com日本| 香蕉久久国产| 国产精品一区二区在线| 国产视频一二三四区| 亚洲第一主播视频| 国产无套内射久久久国产| 欧洲杯什么时候开赛| 精品国产一区二区三区久久狼黑人| 成人免费精品动漫网站| 成人少妇影院yyyy| 欧美亚洲国产免费| 国产精品高清一区二区| 欧美精品一区二区三区一线天视频 | 国产人成视频在线观看| 亚洲成aⅴ人片久久青草影院| 亚洲第一福利网| 毛片网站免费观看| 久久精品久久99精品久久| 亚洲最大成人网色| 香蕉国产在线视频| 欧美日韩免费视频| 中文在线观看免费视频| 日韩电影在线观看网站| 国产成人在线免费| 91欧美视频网站| 亚洲国产综合一区| 在线看国产一区| 色99之美女主播在线视频| 女女百合国产免费网站| 欧美日韩一区二区三区四区不卡 | 草草久久久无码国产专区| 精品久久久久中文字幕小说 | 亚洲草久电影| 日本韩国在线不卡| 国产免费无遮挡| 色嗨嗨av一区二区三区| 久久久久中文字幕亚洲精品 | 成人av在线网站| 亚洲午夜激情| 亚洲宅男一区| 隔壁老王国产在线精品| 91好色先生tv| 色噜噜狠狠色综合欧洲selulu| 中文字幕在线视频一区二区| 日韩经典中文字幕一区| 国产精品swag| 日韩一区网站| 爱福利视频一区| 日日夜夜狠狠操| 亚洲成人免费电影| 又黄又爽又色的视频| 久久久999| 久久久久网址| 国产精品2023| 久久成人精品一区二区三区| 波多野结衣在线电影| 天天色综合天天| 女同性αv亚洲女同志| 极品少妇xxxx精品少妇偷拍 | 国产午夜伦鲁鲁| 韩日成人av| 亚洲伊人久久综合| а天堂中文最新一区二区三区| 亚洲区中文字幕| 黄瓜视频在线免费观看| 欧美性xxxxxx| 右手影院亚洲欧美| 93久久精品日日躁夜夜躁欧美| 国产一二三区在线播放| 欧美+亚洲+精品+三区| 成人免费网站在线观看| 亚洲色图综合| 日韩视频免费在线| 在线免费观看中文字幕| 欧美私模裸体表演在线观看| www.av天天| 久久精品亚洲麻豆av一区二区| 日本a级片免费观看| 国产精品乱看| 久久久久久九九九九| 一区三区在线欧| 国产91在线播放精品91| 欧美精选视频一区二区| 亚洲一二三在线| 波多野结衣电影在线播放| 欧美日韩免费观看一区二区三区| 午夜黄色福利视频| 综合在线观看色| www.黄色网| fc2成人免费人成在线观看播放| 福利视频一区二区三区四区| 性一交一乱一区二区洋洋av| 欧美日韩在线一区二区三区| 日韩夫妻性生活xx| 成人午夜黄色影院| 57pao国产一区二区| 国语自产精品视频在线看一大j8| 黄色a级在线观看| 日韩电影网站| 夜夜嗨av色综合久久久综合网| 日本欧美www| 7777精品伊人久久久大香线蕉完整版 | 成人影视亚洲图片在线| 日韩av电影免费观看高清| 99久久久国产精品免费调教网站 | 欧美一级淫片aaaaaa| 日韩av综合网站| 艳妇乳肉豪妇荡乳av无码福利 | 亚洲精品天堂成人片av在线播放| 国模大胆一区二区三区| 久久久久久久免费| 久久久久久久久国产一区| 草莓视频一区| 国产一区二区在线| 91日韩在线播放| 日本一区福利在线| 91精品国产综合久久男男| ccyy激情综合| 欧美深性狂猛ⅹxxx深喉| 性色av一区二区怡红| 天天好比中文综合网| 在线观看一二三区| 久久先锋资源网| 视频二区在线播放| 懂色一区二区三区免费观看| 欧美aⅴ在线观看| 黄一区二区三区| 97视频在线免费| 久久精品国产77777蜜臀| 真实国产乱子伦对白视频| 视频一区二区三区中文字幕| 国产a级片免费看| 性xx色xx综合久久久xx| eeuss中文| 视频在线观看一区| 黄色三级中文字幕| 久久国产福利国产秒拍| 日韩av黄色网址| 国产黄人亚洲片| 亚洲xxx在线观看| 久久综合色8888| 免费高清视频在线观看| 国产清纯在线一区二区www| 中文字幕人妻一区| 亚洲男同性视频| 日韩视频在线观看免费视频| 亚洲成人在线网站| 欧美国产精品一二三| 欧美日韩精品福利| 色av性av丰满av| 日韩精品中文字幕在线播放| 国产高清免费av| 久久精品视频亚洲| 国产91亚洲精品久久久| 欧美专区国产专区| 精品网站aaa| 成人午夜影院在线观看| 神宫寺奈绪一区二区三区| 成人激情av网| 夫妻免费无码v看片| 高清不卡一二三区| 两性午夜免费视频| 综合久久久久综合| 日本视频在线免费| 欧美日韩视频第一区| 天天干天天操天天操| 国产视频丨精品|在线观看| 狠狠躁日日躁夜夜躁av| 欧美乱大交xxxxx| 午夜日韩影院| 产国精品偷在线| 一区在线观看| 分分操这里只有精品| 99精品欧美一区二区三区小说 | 18禁网站免费无遮挡无码中文 | 人妻内射一区二区在线视频| 91免费看片在线观看| av黄色一级片| 日韩欧美一区二区在线| 亚洲影院在线播放| 亚洲天堂免费视频| 国产69精品久久| 91夜夜未满十八勿入爽爽影院| 五月天久久久| 久久www视频| 成人网在线免费视频| 免费观看一级一片| 日韩欧美一区二区三区久久| 波多野结衣 久久| 国产一区二区三区精品久久久| 福利一区和二区| 亚洲在线一区二区| 日韩午夜免费视频| 免费国产成人av| 最新中文字幕一区二区三区| 青青草偷拍视频| 久久99久久人婷婷精品综合| 欧美成人精品xxx| 2023国产精华国产精品| 国产伦精品一区二区三区在线| 99视频精品免费观看| 日韩精品一区二区三区色欲av| 中文字幕av一区二区三区高| 卡通动漫亚洲综合| 亚洲精品国产精品自产a区红杏吧| 奇米777日韩| 亚洲free性xxxx护士hd| 日韩一级大片| 无人在线观看的免费高清视频| 中文字幕一区二区三区av| 久久精品性爱视频| 亚洲天堂影视av| 国产va免费精品观看精品| 国产一区二区久久久| 日产欧产美韩系列久久99| 91蝌蚪视频在线| 亚洲一二三专区| 国产一级片免费在线观看| 久久伊人精品一区二区三区| 久久影院资源站| 亚洲国产一区二区精品视频| 国产成人精品一区二区三区四区 | 日韩在线激情视频| 六月丁香久久丫| 91手机视频在线| wwwwww.欧美系列| 免费国产羞羞网站美图| 亚洲人成电影网站|