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

AJAX:如何處理書簽和后退按鈕_Xml教程

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

推薦:如何得到XML文檔文件的大小
XML文檔從格式到大小都是不是確定的。有的可能只有幾行,而有的卻有好幾兆字節(jié)。你也許會懷疑是不是需要了解XML文檔的大小。而當(dāng)性能成為首要問題時,知道XML文檔大小就是件必須要作的

本文將展示一個開源JavaScript庫,該腳本庫給AJAX應(yīng)用程序帶來了書簽和后退按鈕支持。在學(xué)習(xí)完這個教程后,開發(fā)人員將能夠獲得對一個AJAX問題的解決方案(甚至連Google Maps和Gmail現(xiàn)在都不提供該解決方案):一個強(qiáng)大的、可用的書簽和后退前進(jìn)功能,其操作行為如同其他的Web應(yīng)用程序一樣。

本文將闡述目前AJAX應(yīng)用程序在使用書簽和后退按鈕方面所面臨的嚴(yán)重問題;展示Really Simple History(RSH)庫——一個可以解決以上問題的開源框架,并提供幾個運(yùn)行中的例子。

本文所展示的這個框架的主要發(fā)明分為兩部分。首先是一個隱藏的HTML表單,用于緩存大量短期會話的客戶端信息;這種緩存功能為頁面導(dǎo)航提供了強(qiáng)大的支持。其次是超鏈接錨點(diǎn)和隱藏Iframe的組合,它們被嵌入后退和前進(jìn)按鈕,用來截獲和記錄瀏覽器的歷史記錄事件。以上兩種技術(shù)都被包裝在一個簡單的JavaScript庫中來簡化開發(fā)。

問題

書簽和后退按鈕在傳統(tǒng)的多頁面Web應(yīng)用程序中運(yùn)行得非常好。當(dāng)用戶瀏覽web站點(diǎn)的時候,其瀏覽器的地址欄記錄隨新的URL而更新,這些記錄可以被粘貼到電子郵件或者書簽中供以后使用。后退和前進(jìn)按鈕也可以正常操作,使用戶可以在訪問過的頁面中向前或向后翻動。

但是AJAX應(yīng)用程序卻不一樣,它們是運(yùn)行在單個Web頁面中的復(fù)雜程序。瀏覽器并不是為這類程序而構(gòu)建的——這類Web應(yīng)用程序已經(jīng)過時,它們在每次鼠標(biāo)點(diǎn)擊的時候都需要重新刷新整個頁面。

在這種類似于Gmail的AJAX軟件中,瀏覽器的地址欄在用戶選擇功能和改變程序狀態(tài)的時候保持不變,這使得無法在特定的應(yīng)用程序視圖中使用書簽。此外,如果用戶按下“后退”按鈕來“撤銷”上次的操作,他們會驚奇地發(fā)現(xiàn),瀏覽器會完全離開該應(yīng)用程序的Web頁面。

解決方案

開源RSH框架可以解決這些問題,它為AJAX應(yīng)用程序提供了書簽和控制后退、前進(jìn)按鈕的功能。RSH目前還處于Beta階段,可以在Firefox 1.0、Netscape 7 、Internet Explorer 6 等瀏覽器上運(yùn)行;目前還不支持Safari。

目前有幾個AJAX框架對書簽和歷史記錄問題有所幫助;但這些框架目前都有幾個由于實(shí)現(xiàn)而造成的重大Bug。此外,很多AJAX歷史記錄框架被綁定到較大的庫上,例如Backbase和Dojo;這些框架為AJAX應(yīng)用程序引入了完全不同的編程模型,迫使開發(fā)人員使用全新的方式來獲得歷史記錄功能。

相較之下,RSH是一個可以包含在現(xiàn)有AJAX系統(tǒng)中的簡單模塊。此外,RSH庫采用了一些技術(shù)以避免產(chǎn)生影響其他歷史記錄框架的Bug。

RSH框架由兩個JavaScript類組成:DhtmlHistory和HistoryStorage。

DhtmlHistory類為AJAX應(yīng)用程序提供歷史記錄抽象。AJAX頁面使用add()方法添加歷史記錄事件到瀏覽器,指定新的地址和相關(guān)的歷史記錄數(shù)據(jù)。DhtmlHistory類使用一個錨散列(如#new-location)更新瀏覽器當(dāng)前的URL,同時把歷史記錄數(shù)據(jù)和該新URL關(guān)聯(lián)。AJAX應(yīng)用程序?qū)⒆约鹤詾闅v史記錄的監(jiān)聽器,當(dāng)用戶使用后退和前進(jìn)按鈕進(jìn)行瀏覽時,歷史記錄事件被觸發(fā),為瀏覽器提供新的位置以及與add()調(diào)用一起保存的任何歷史記錄數(shù)據(jù)。

第二個類:HistoryStorage,允許開發(fā)人員保存任意數(shù)量的已存歷史記錄數(shù)據(jù)。在普通Web頁面中,當(dāng)用戶導(dǎo)航到一個新的web站點(diǎn)時,瀏覽器卸載并清除web頁面上的所有應(yīng)用程序和JavaScript狀態(tài);如果用戶用后退按鈕返回,所有的數(shù)據(jù)都丟失了。HistoryStorage類通過一個包含簡單散列表方法(例如put()、get()、hasKey())的API來解決這類問題。上面的方法允許開發(fā)人員在用戶離開Web頁面之后保存任意數(shù)量的數(shù)據(jù);當(dāng)用戶按后退按鈕重新返回時,歷史記錄數(shù)據(jù)可以通過HistoryStorage類來訪問。在內(nèi)部,我們通過使用隱藏的表單字段來實(shí)現(xiàn)此功能,這是因為瀏覽器會自動保存表單字段中的值,甚至在用戶離開Web頁面的時候也如此。

例子

讓我們先從一個簡單的例子開始。

首先,任何需要使用RSH框架的頁面都必須包含dhtmlHistory.js腳本:

以下為引用的內(nèi)容:
<!-- Load the Really Simple
History framework -->
<script type="text/javascript"
src="../../framework/dhtmlHistory.js">
</script>

DHTML歷史記錄應(yīng)用程序也必須在與AJAX Web頁面相同的目錄下包含blank.html文件;這個文件與RSH框架打包在一起,且對于Internet Explorer來說是必需的。順便提一下,RSH使用一個隱藏Iframe來跟蹤和添加Internet Explorer的歷史記錄變化;這個Iframe需要我們指定一個實(shí)際的文件位置才能正常工作,這就是blank.html。

RSH框架創(chuàng)建了一個叫做dhtmlHistory的全局對象,這是操縱瀏覽器歷史記錄的入口點(diǎn)。使用dhtmlHistory的第一步是在Web頁面加載完成后初始化dhtmlHistory對象:

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

然后,開發(fā)人員使用dhtmlHistory.addListener()方法訂閱歷史記錄變化事件。這個方法帶有一個JavaScript回調(diào)函數(shù),當(dāng)DHTML歷史記錄變化事件發(fā)生時,該函數(shù)接收兩個參數(shù):新的頁面位置以及任何可與該事件關(guān)聯(lián)的可選歷史記錄數(shù)據(jù):

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

 // subscribe to DHTML history change
 // events
 dhtmlHistory.addListener(historyChange);
  historyChange()方法很簡單,該函數(shù)在用戶導(dǎo)航到一個新位置后接收newLocation以及任何與該事件關(guān)聯(lián)的可選historyData。

/** Our callback to receive history change
events. */
function historyChange(newLocation,
historyData) {
 debug("A history change has occurred: "
   "newLocation=" newLocation
   ", historyData=" historyData,
  true);
}

上面用到的debug()方法是定義在示例源文件中的一個實(shí)用函數(shù),它與完整示例打包在一起供下載。debug()只是用來將消息打印到Web頁面上;第二個布爾型參數(shù)(在上述代碼中值為true)控制是否在打印新的調(diào)試消息之前清除原有的全部消息。

開發(fā)人員使用add()方法添加歷史記錄事件。添加歷史記錄事件涉及為歷史記錄變化指定一個新地址,例如edit:SomePage,以及提供一個和該事件一起保存的可選historyData值。

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

 // subscribe to DHTML history change
 // events
 dhtmlHistory.addListener(historyChange);

 // if this is the first time we have
 // loaded the page...
 if (dhtmlHistory.isFirstLoad()) {
  debug("Adding values to browser " "history", false);
  // start adding history
  dhtmlHistory.add("helloworld", "Hello World Data");
  dhtmlHistory.add("foobar", 33);
  dhtmlHistory.add("boobah", true);

  var complexObject = new Object();
  complexObject.value1 = "This is the first value";
  complexObject.value2 = "This is the second data";
  complexObject.value3 = new Array();
  complexObject.value3[0] = "array 1";
  complexObject.value3[1] = "array 2";

  dhtmlHistory.add("complexObject", complexObject);

在add()被調(diào)用之后,新的地址將立即作為一個錨值(鏈接地址)顯示在瀏覽器的URL地址欄中。例如,對地址為http://codinginparadise.org/my_ajax_app的AJAX Web頁面調(diào)用dhtmlHistory.add("helloworld", "Hello World Data")之后,用戶將會在其瀏覽器URL地址欄中看到如下的地址:

http://codinginparadise.org/my_ajax_app#helloworld

然后用戶可以將這個頁面做成書簽,如果以后用到這個書簽,AJAX應(yīng)用程序可以讀取#helloworld值,并用它來初始化Web頁面。散列后面的地址值是RSH框架可以透明編碼和解碼的URL地址。

HistoryData非常有用,它保存比簡單的URL更為復(fù)雜的AJAX地址變化狀態(tài)。這是一個可選值,可以是任何JavaScript類型,例如Number、String或Object。使用該保存功能的一個例子是在一個富文本編輯器中保存所有文本(比如在用戶離開當(dāng)前頁面時)。當(dāng)用戶再回到這個地址時,瀏覽器將會將該對象返回給歷史記錄變化監(jiān)聽器。

開發(fā)人員可以為historyData提供帶有嵌套對象和表示復(fù)雜狀態(tài)的數(shù)組的完整JavaScript對象;JSON (JavaScript Object Notation)所支持的在歷史記錄數(shù)據(jù)中都支持,包括簡單數(shù)據(jù)類型和null類型。然而,DOM對象以及可用腳本編寫的瀏覽器對象(如XMLHttpRequest)不會被保存。請注意,historyData并不隨書簽一起保存,當(dāng)瀏覽器關(guān)閉,瀏覽器緩存被清空,或者用戶清除歷史記錄的時候,它就會消失。

使用dhtmlHistory的最后一步是isFirstLoad()方法。在某些瀏覽器中,如果導(dǎo)航到一個Web頁面,再跳轉(zhuǎn)到另一個不同的頁面,然后按“后退”按鈕返回到起始的站點(diǎn),第一頁將完全重新加載,并觸發(fā)onload事件。這樣會對想要在第一次加載頁面時用某種方式對其進(jìn)行初始化(而其后則不使用這種方式重新加載該頁面)的代碼造成破壞。isFirstLoad()方法可以區(qū)分是第一次加載一個Web頁面還是用戶導(dǎo)航到保存在歷史記錄中的Web頁面時觸發(fā)的“假加載”事件。

在示例代碼中,我們只想在第一次加載頁面的時候添加歷史記錄事件;如果用戶在加載頁面后按后退按鈕返回該頁面,我們就不想重新添加任何歷史記錄事件:

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

 // subscribe to DHTML history change
 // events
 dhtmlHistory.addListener(historyChange);

 // if this is the first time we have
 // loaded the page...
 if (dhtmlHistory.isFirstLoad()) {
  debug("Adding values to browser " "history", false);
  // start adding history
  dhtmlHistory.add("helloworld", "Hello World Data");
  dhtmlHistory.add("foobar", 33);
  dhtmlHistory.add("boobah", true);

  var complexObject = new Object();
  complexObject.value1 = "This is the first value";
  complexObject.value2 = "This is the second data";
  complexObject.value3 = new Array();
  complexObject.value3[0] = "array 1";
  complexObject.value3[1] = "array 2";

  dhtmlHistory.add("complexObject", complexObject);

讓我們繼續(xù)使用historyStorage類。類似于dhtmlHistory,historyStorage通過一個叫historyStorage的全局對象來公開它的功能。該對象有幾個模擬散列的方法,比如put(keyName、keyValue)、get(keyName)和hasKey(keyName)。鍵名稱必須是字符串,同時鍵值可以是復(fù)雜的JavaScript對象甚至是XML格式的字符串。在我們的源代碼例子中,在第一次加載頁面時,我們使用put()將簡單的XML放入historyStorage:

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

 // subscribe to DHTML history change
 // events
 dhtmlHistory.addListener(historyChange);

 // if this is the first time we have
 // loaded the page...
 if (dhtmlHistory.isFirstLoad()) {
  debug("Adding values to browser " "history", false);
  // start adding history
  dhtmlHistory.add("helloworld", "Hello World Data");
  dhtmlHistory.add("foobar", 33);
  dhtmlHistory.add("boobah", true);

  var complexObject = new Object();
  complexObject.value1 = "This is the first value";
  complexObject.value2 = "This is the second data";
  complexObject.value3 = new Array();
  complexObject.value3[0] = "array 1";
  complexObject.value3[1] = "array 2";

  dhtmlHistory.add("complexObject", complexObject);

  // cache some values in the history
  // storage
  debug("Storing key 'fakeXML' into " "history storage", false);
  var fakeXML =
   '<?xml version="1.0" '
    'encoding="ISO-8859-1"?>'
    '<foobar>'
    '<foo-entry/>'
    '</foobar>';
  historyStorage.put("fakeXML", fakeXML);
}

然后,如果用戶離開頁面后又通過后退按鈕返回該頁面,我們可以使用get()方法提取保存的值,或者使用hasKey()方法檢查該值是否存在。

以下為引用的內(nèi)容:

window.onload = initialize;

function initialize() {
 // initialize the DHTML History
 // framework
 dhtmlHistory.initialize();

 // subscribe to DHTML history change
 // events
 dhtmlHistory.addListener(historyChange);

 // if this is the first time we have
 // loaded the page...
 if (dhtmlHistory.isFirstLoad()) {
  debug("Adding values to browser " "history", false);
  // start adding history
  dhtmlHistory.add("helloworld", "Hello World Data");
  dhtmlHistory.add("foobar", 33);
  dhtmlHistory.add("boobah", true);

  var complexObject = new Object();
  complexObject.value1 = "This is the first value";
  complexObject.value2 = "This is the second data";
  complexObject.value3 = new Array();
  complexObject.value3[0] = "array 1";
  complexObject.value3[1] = "array 2";

  dhtmlHistory.add("complexObject", complexObject);

  // cache some values in the history
  // storage
  debug("Storing key 'fakeXML' into " "history storage", false);
  var fakeXML = '<?xml version="1.0" ' 'encoding="ISO-8859-1"?>'
    '<foobar>' '<foo-entry/>' '</foobar>';
  historyStorage.put("fakeXML", fakeXML);
 }

 // retrieve our values from the history
 // storage
 var savedXML = historyStorage.get("fakeXML");
 savedXML = prettyPrintXml(savedXML);
 var hasKey = historyStorage.hasKey("fakeXML");
 var message = "historyStorage.hasKey('fakeXML')="
    hasKey "<br>"
    "historyStorage.get('fakeXML')=<br>"
    savedXML;
 debug(message, false);
}

prettyPrintXml()是一個定義在完整示例源代碼中的實(shí)用方法;此函數(shù)準(zhǔn)備在web頁面中顯示以便用于調(diào)試的簡單XML。


請注意,相關(guān)數(shù)據(jù)只在該頁面的歷史記錄中進(jìn)行持久化;如果瀏覽器被關(guān)閉,或者用戶打開一個新窗口并再次鍵入AJAX應(yīng)用程序的地址,則該歷史記錄數(shù)據(jù)對于新的Web頁面不可用。歷史記錄數(shù)據(jù)只有在用到后退或前進(jìn)按鈕時才被持久化,當(dāng)用戶關(guān)閉瀏覽器或清空緩存的時候就會消失。如果想真正長期持久化,請參閱Ajax MAssive Storage System (AMASS)。

我們的簡單示例已經(jīng)完成。

示例2:O'Reilly Mail

我們的第二個例子是一個簡單的AJAX電子郵件模擬應(yīng)用程序的示例,即O'Reilly Mail,它類似于Gmail。O'Reilly Mail描述了如何使用dhtmlHistory類來控制瀏覽器的歷史記錄,以及如何使用historyStorage對象來緩存歷史記錄數(shù)據(jù)。

O'Reilly Mail用戶界面由兩部分組成。在頁面的左邊是一個帶有不同電子郵件文件夾和選項的菜單,例如收件箱、草稿箱等。當(dāng)用戶選擇了一個菜單項(如收件箱),就用這個菜單項的內(nèi)容更新右邊的頁面。在一個現(xiàn)實(shí)應(yīng)用程序中,我們會遠(yuǎn)程獲取并顯示選擇的信箱內(nèi)容,不過在O'Reilly Mail中,我們只顯示已選擇的選項。

O'Reilly Mail使用RSH框架向瀏覽器歷史記錄中添加菜單變化并更新地址欄,允許用戶利用瀏覽器的后退和前進(jìn)按鈕為應(yīng)用程序做收藏書簽和跳到上次變化的菜單。

我們添加一個特殊的菜單項——地址簿,以說明如何來使用historyStorage。地址簿是一個由聯(lián)系人名稱和郵件地址組成的JavaScript數(shù)組,在一個現(xiàn)實(shí)應(yīng)用程序中,我們會從一臺遠(yuǎn)程服務(wù)器取得這個數(shù)組。不過,在O'Reilly Mail中,我們在本地創(chuàng)建這個數(shù)組,添加幾個名稱和電子郵件地址,然后將其保存在historyStorage對象中。如果用戶離開Web頁面后又返回該頁面,那么O'Reilly Mail應(yīng)用程序?qū)⒅匦聫木彺鏅z索地址簿,而不是再次聯(lián)系遠(yuǎn)程服務(wù)器。

我們用initialize()方法保存和檢索地址簿:

以下為引用的內(nèi)容:

/** Our function that initializes when the page
is finished loading. */
function initialize() {
// initialize the DHTML History framework
dhtmlHistory.initialize();

// add ourselves as a DHTML History listener
dhtmlHistory.addListener(handleHistoryChange);

// if we haven't retrieved the address book
// yet, grab it and then cache it into our
// history storage
if (window.addressBook == undefined) {
 // Store the address book as a global
 // object.
 // In a real application we would remotely
 // fetch this from a server in the
 // background.
 window.addressBook =
  ["Brad Neuberg 'bkn3@columbia.edu'",
  "John Doe 'johndoe@example.com'",
  "Deanna Neuberg 'mom@mom.com'"];

 // cache the address book so it exists
 // even if the user leaves the page and
 // then returns with the back button
 historyStorage.put("addressBook", addressBook);
}
else {
 // fetch the cached address book from
 // the history storage
 window.addressBook = historyStorage.get("addressBook");
}

處理歷史記錄變化的代碼也很簡單。在下面的源代碼中,無論用戶按后退還是前進(jìn)按鈕,都將調(diào)用handleHistoryChange。使用O'Reilly Mail定義的displayLocation實(shí)用方法,我們可得到newLocation并使用它將我們的用戶界面更新到正確的狀態(tài)。

以下為引用的內(nèi)容:

/** Handles history change events. */
function handleHistoryChange(newLocation,
historyData) {
 // if there is no location then display
 // the default, which is the inbox
 if (newLocation == "") {
  newLocation = "section:inbox";
 }

 // extract the section to display from
 // the location change; newLocation will
 // begin with the word "section:"
 newLocation = newLocation.replace(/section\:/, "");

 // update the browser to respond to this
 // DHTML history change
 displayLocation(newLocation, historyData);
}

/** Displays the given location in the
right-hand side content area. */
function displayLocation(newLocation,sectionData) {
 // get the menu element that was selected
 var selectedElement = document.getElementById(newLocation);

 // clear out the old selected menu item
 var menu = document.getElementById("menu");
 for (var i = 0; i < menu.childNodes.length; i ) {
  var currentElement = menu.childNodes[i];
  // see if this is a DOM Element node
  if (currentElement.nodeType == 1) {
   // clear any class name
   currentElement.className = "";
  }
 }

 // cause the new selected menu item to
 // appear differently in the UI
 selectedElement.className = "selected";

 // display the new section in the right-hand
 // side of the screen; determine what
 // our sectionData is

 // display the address book differently by
 // using our local address data we cached
 // earlier
 if (newLocation == "addressbook") {
  // format and display the address book
  sectionData = "<p>Your addressbook:</p>";
  sectionData = "<ul>";

  // fetch the address book from the cache
  // if we don't have it yet
  if (window.addressBook == undefined) {
   window.addressBook = historyStorage.get("addressBook");
  }

  // format the address book for display
  for (var i = 0; i < window.addressBook.length; i ) {
   sectionData = "<li>"
     window.addressBook[i]
     "</li>";
  }

  sectionData = "</ul>";
 }

 // If there is no sectionData, then
 // remotely retrieve it; in this example
 // we use fake data for everything but the
 // address book
 if (sectionData == null) {
  // in a real application we would remotely
  // fetch this section's content
  sectionData = "<p>This is section: "
selectedElement.innerHTML "</p>";
 }

 // update the content's title and main text
 var contentTitle = document.getElementById("content-title");
 var contentValue = document.getElementById("content-value");
 contentTitle.innerHTML = selectedElement.innerHTML;
 contentValue.innerHTML = sectionData;
}

結(jié)束語

現(xiàn)在我們已經(jīng)了解了如何使用RSH API來使AJAX應(yīng)用程序支持書簽以及后退和前進(jìn)按鈕,并提供了示例代碼,您可參考該示例來創(chuàng)建自己的應(yīng)用程序。希望您能利用書簽和歷史記錄的支持來增強(qiáng)AJAX應(yīng)用程序。

分享:如何用ASP生成XML數(shù)據(jù)文檔
  一、必須弄清楚最終需要的是什么   我們通過asp或其他動態(tài)編程語言,最終需要的是XML格式的數(shù)據(jù),這點(diǎn)和XML數(shù)據(jù)所在的文件載體無關(guān),它可以是實(shí)實(shí)在在的XML文件,比如:http://www.d

來源:模板無憂//所屬分類:Xml教程/更新時間:2008-08-22
相關(guān)Xml教程
超在线视频97| av综合在线播放| 欧美日韩成人激情| 91亚洲va在线va天堂va国| √天堂资源在线| 国产精品久久在线观看| 免费在线观看91| 综合 欧美 亚洲日本| 成人网av.com/| 成人国产精品免费网站| 国产亚洲激情在线| japanese在线播放| 日韩欧美a级片| 青青草国产免费一区二区下载| 亚洲欧洲综合另类在线| 91国产中文字幕| 91丨九色丨蝌蚪| 日本黄色免费视频| 麻豆精品国产91久久久久久 | jizz日本在线播放| 国产三级精品三级在线观看国产| 久久久久国产精品麻豆ai换脸 | 日韩www.| 亚洲sss视频在线视频| 国产精品流白浆视频| 最新日本中文字幕| 黄色成人小视频| 99国产精品99久久久久久| 日韩一区二区三区xxxx| 成人综合视频在线| 国产视频www| 蜜臀久久99精品久久久画质超高清| 精品国精品国产尤物美女| 视频一区免费观看| 欧美videossex极品| 国产在线成人| 欧美一区二区三区视频在线观看 | 亚洲小视频在线播放| 秋霞精品一区二区三区| 黄色综合网站| 日韩一区二区三区av| 亚洲精品久久区二区三区蜜桃臀| 国产精品视频免费播放| 国产精品jizz在线观看美国| 欧美精品一卡两卡| 日韩视频在线播放| 久久国产视频精品| 亚洲一区一卡| 亚洲精品v天堂中文字幕| 红桃一区二区三区| 97人妻精品一区二区三区软件| 天堂蜜桃91精品| 亚洲欧美日韩国产精品| 2019日韩中文字幕mv| 成人黄色在线观看视频| 国产一区91精品张津瑜| 自拍视频国产精品| 天堂社区在线视频| 日韩成人亚洲| 国产无遮挡一区二区三区毛片日本| 久久人人爽人人爽人人片av高清| 天天操夜夜操很很操| 亚洲精品一区av| 国产精品久久久久久久第一福利 | 久久99视频精品| 欧美性猛交xxxx乱大交91| 成人免费观看49www在线观看| 中文字幕在线免费不卡| 91久久精品在线| 精品无码久久久久成人漫画| 99视频精品全部免费在线视频| 欧美吻胸吃奶大尺度电影 | 美女视频久久黄| 国产黑丝在线视频| 成人在线视频你懂的| 亚洲成人动漫av| 狠狠色噜噜狠狠狠狠色吗综合 | 欧美性做爰猛烈叫床潮| 亚欧洲精品在线视频免费观看| 超碰在线免费97| 久久精品国内一区二区三区| 啊v视频在线一区二区三区| www.色就是色.com| 超碰成人在线观看| 日韩欧美中文字幕在线观看| 欧美另类一区| 中文字幕第一页在线播放| 精品在线观看视频| 欧美高清在线观看| 右手影院亚洲欧美| 国产精品99久久精品| 亚洲成av人片在线观看香蕉| 欧美精品色婷婷五月综合| 成人做爰视频www| 亚洲精品国产一区二区精华液 | 亚洲理伦在线| 最近2019免费中文字幕视频三| 亚洲精品第三页| 国产美女撒尿一区二区| 91福利区一区二区三区| 中国老女人av| 亚洲伊人av| 日韩理论片在线| 国产免费一区| 亚洲一区二区色| 99精品国产视频| 成人黄色在线播放| 亚洲欧美在线视频免费| 久久99久久精品| 欧美性在线观看| 亚洲国产精品一区二区久久hs| 欧美日韩亚洲一区二区三区在线| 日韩精品中文字幕视频在线| 制服丝袜中文字幕第一页 | 我不卡伦不卡影院| 精品一区电影国产| 青娱乐国产精品视频| 免费欧美一区| 欧美成人激情免费网| 日本成人在线免费视频| jazzjazz国产精品麻豆| 欧美日本一区二区三区四区| 男人日女人逼逼| 中文字幕一区二区三区日韩精品| 色94色欧美sute亚洲线路二| 18禁裸男晨勃露j毛免费观看| 看片一区二区| 色婷婷综合久久久久中文一区二区| 国产奶头好大揉着好爽视频| 成人在线爆射| 色综合色狠狠综合色| 久久亚洲a v| 91精品国产色综合久久不卡粉嫩| 色综合久久中文综合久久97 | 日本少妇一区二区| 91禁国产网站| 久久一区二区三| 国产精品一区二区在线观看不卡| 国产91热爆ts人妖在线| 国产福利拍拍拍| 成人黄色网址在线观看| 99影视tv| www.亚洲欧美| 一级做a爱片久久| 99热一区二区三区| 97色婷婷成人综合在线观看| 欧美性猛交一区二区三区精品| 北条麻妃在线观看| 青青一区二区| 亚洲国产欧美精品| 三级视频网站在线观看| 亚洲电影成人| 久久久天堂国产精品女人| 国模无码国产精品视频| 国产aⅴ综合色| 亚洲自拍欧美色图| 超碰福利在线观看| 亚洲第一在线综合网站| av网站手机在线观看| 国产日韩三级| 日韩毛片在线看| 精品无码人妻一区二区免费蜜桃| 日韩av在线发布| 欧洲美女免费图片一区| 一二三区免费视频| 中文久久乱码一区二区| 亚洲欧洲日韩综合二区| av在线亚洲一区| 欧美一二三四在线| av天堂一区二区| 国产亚洲一级| 国产成人亚洲综合91| 最近国语视频在线观看免费播放| 亚洲欧美综合另类在线卡通| 中国老女人av| 欧美日韩导航| 亚洲天堂视频在线观看| 91禁男男在线观看| 国产成人综合网站| 极品尤物一区二区三区| 午夜欧美巨大性欧美巨大| 欧美三级视频在线| 巨乳女教师的诱惑| 亚洲少妇自拍| 国产精品久久久久久亚洲影视 | 亚洲高清免费观看高清完整版| 老熟妇精品一区二区三区| 久久成人一区| 国产日韩精品综合网站| 国产91久久久| 欧美在线观看视频在线| 免费成人黄色大片| 中文亚洲欧美| 国产免费一区视频观看免费| 亚洲男人天堂久久| 欧美在线三级电影| 亚洲 自拍 另类 欧美 丝袜| 麻豆91精品| **亚洲第一综合导航网站| 婷婷丁香一区二区三区| 欧美日韩国产综合视频在线观看 | 亚洲av综合色区无码一二三区 | 日韩三级在线免费观看| 成人免费网站黄| 国产一区二区伦理片| 久久精品午夜一区二区福利| 婷婷激情成人| 亚洲精品国精品久久99热| 欧美性生给视频| 91免费在线视频观看| 91免费视频黄| 国产探花一区在线观看| 欧美激情手机在线视频 | 国产麻豆一区二区三区| 日韩第一页在线| 国产一二三四区| 国产欧美va欧美不卡在线 | 老汉av免费一区二区三区| 国内精品国语自产拍在线观看| av成人免费| 日韩av在线网站| 国产大学生自拍| 中文一区一区三区高中清不卡| 免费一级特黄毛片| 自由日本语亚洲人高潮| 国产精品久久久久久久久久久新郎| 韩国av免费在线| 91精品久久久久久久99蜜桃 | 亚洲综合精品自拍| 手机免费av片| 蜜臀99久久精品久久久久久软件| 九色91在线视频| eeuss国产一区二区三区四区| 久久九九国产精品怡红院| 久久精品视频2| 黑人与娇小精品av专区| 亚洲精品成a人| 免费在线成人av| 美腿丝袜亚洲图片| 欧美精品亚州精品| 国产尤物视频在线观看| 欧洲亚洲国产日韩| 在线国产视频一区| 久久综合资源网| 黄色一级视频片| 亚洲精选一区| 精品乱码一区二区三区| 精品按摩偷拍| 亚洲 日韩 国产第一| 亚洲老妇色熟女老太| 日韩欧美一区二区免费| 欧美日韩三级在线观看| 一区二区三区在线视频免费| 老司机午夜性大片| 毛片av一区二区| 亚洲欧美电影在线观看| 日韩欧美字幕| 91美女高潮出水| 99精品国产九九国产精品| 精品国产一区二区三区四区在线观看 | 日本妇女一区| 91高清在线免费观看| 午夜影院免费体验区| 日韩电影免费观看中文字幕| 毛片毛片女人毛片毛片| 91福利精品第一导航| 大吊一区二区三区| 亚洲欧美偷拍另类a∨色屁股| 国产精品久久久久久9999| 国产一区二区不卡| 黄色片网址在线观看| 免费视频一区二区三区在线观看| 免费日韩电影在线观看| 日韩精品中文字幕第1页| 91免费电影网站| 91麻豆精品激情在线观看最新| 欧美激情一区二区三级高清视频| 黄色av免费观看| 亚洲精品一区二区网址| 中文字幕乱码视频| 日韩亚洲欧美成人一区| 国产精品第一页在线观看| 欧美日韩一区二区精品| 欧美日韩国产一二三区| 一区二区三区.www| 极品白嫩丰满美女无套| 亚洲国产成人自拍| 男人添女人荫蒂国产| 久久久久久久一区| 国内自拍第二页| 99视频一区二区| 国内国产精品天干天干| 成人免费观看视频| 国产一二三四在线视频| 国产成人日日夜夜| 成人免费观看毛片| 精品无人码麻豆乱码1区2区| 激情小视频网站| 日本成人在线不卡视频| 久久手机在线视频| 奇米四色…亚洲| 69sex久久精品国产麻豆| 青青草97国产精品免费观看 | 狠狠做六月爱婷婷综合aⅴ| 国产专区精品视频| 怡红院av久久久久久久| 亚洲欧洲一区| 日韩精品一区二区三区色偷偷| 久久久久久久久久久9不雅视频| 国产综合欧美在线看| 欧美激情电影| 欧美日韩精品免费观看视一区二区| 偷拍欧美精品| 欧美自拍资源在线| 亚洲高清免费| av电影一区二区三区| 日韩中文字幕1| 玩弄中年熟妇正在播放| 国产一区二区三区四区五区入口| 国产亚洲天堂网| 粉嫩aⅴ一区二区三区四区五区| 熟妇人妻无乱码中文字幕真矢织江| 粉嫩av一区二区三区| 亚洲欧美偷拍另类| 国产欧美精品在线观看| 30一40一50老女人毛片| 亚洲午夜激情av| 国产一二三区精品| 欧美天天综合网| wwwwww国产| 亚洲精品不卡在线| 亚洲第一页视频| 久久这里有精品| 国产精品久久久久久久久久久久久久久 | 日韩人妻一区二区三区蜜桃视频| 石原莉奈在线亚洲二区| 日韩精品 欧美| 成人午夜激情在线| 色婷婷狠狠18禁久久| 一区二区三区在线免费| 欧美三级黄色大片| 777午夜精品免费视频| 羞羞色院91蜜桃| 国产亚洲一区精品| 国产综合av| 国产精品99导航| 精品国产123区| 欧美一区二区在线视频观看| 久久人人超碰| 日韩手机在线观看视频| 国产清纯在线一区二区www| 一级黄色性视频| 在线免费视频一区二区| 国产美女www| 中文字幕综合在线| 超碰国产精品一区二页| 91精品啪在线观看麻豆免费| 影视亚洲一区二区三区| 欧美做受777cos| 成人黄色网址在线观看| 91av在线免费| 日本韩国精品在线| 中文字幕精品一区二区精| 久久精品视频播放| av日韩精品| 国产精品国产亚洲精品看不卡15 | 国产成人精彩在线视频九色| 视频一区欧美| 日韩欧美视频一区二区| 精品午夜一区二区三区在线观看| 亚洲免费在线播放视频| 亚洲午夜精品网| 亚洲综合久久网| 日韩中文在线不卡| 日韩激情欧美| 精品国产91亚洲一区二区三区www 精品国产_亚洲人成在线 | 国产精品宾馆在线精品酒店| 亚洲国产成人一区二区三区| 日本 欧美 国产| 亚洲第一精品夜夜躁人人爽| 成人美女视频| 91精品国产综合久久香蕉| 国产一区视频在线观看免费| 亚洲精品无码久久久久久| 国产蜜臀av在线一区二区三区| 九九精品视频免费| 亚洲精品福利在线| 四虎精品在线观看| 狠狠干一区二区| 精品午夜久久福利影院| 欧美xxxxx少妇| 欧美日韩国产高清一区| www.精品久久| 国产脚交av在线一区二区| 欧美日韩精品免费观看视频完整| 女性女同性aⅴ免费观女性恋| 国产精品久久久久国产精品日日| 国产真人真事毛片| 色黄久久久久久| 久久99精品国产自在现线|