精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

深入解讀JavaScript中BOM和DOM

開發 前端
本文應用了很多實例,來解讀JavaScript中BOM和DOM,DOM是一個使程序和腳本有能力動態地訪問和更新文檔的內容、結構以及樣式的平臺和語言中立的接口。,而BOM定義了JavaScript可以進行操作的瀏覽器的各個功能部件的接口。

51CTO之前曾報導過關于JavaScript使用心得匯總:從BOM和DOM談起,在那篇文章中,主要介紹了兩者的基本概念,而本文應用了很多實例,來解讀JavaScript中BOM和DOM。

BOM定義了JavaScript可以進行操作的瀏覽器的各個功能部件的接口,提供訪問文檔各個功能部件(如窗口本身、屏幕功能部件、瀏覽歷史記錄等)的途徑以及操作方法。

遺憾的是,BOM只是JavaScript腳本實現的一部分,沒有任何相關的標準,每種瀏覽器都有自己的BOM實現,這可以說是BOM的軟肋所在通常情況下瀏覽器特定的JavaScript擴展都被看作BOM的一部分,主要包括:

◆關閉、移動瀏覽器及調整瀏覽器窗口大小;
◆彈出新的瀏覽器窗口;
◆提供瀏覽器詳細信息的定位對象;
◆提供載入到瀏覽器窗口的文檔詳細信息的定位對象;
◆提供用戶屏幕分辨率詳細信息的屏幕對象;
◆提供對cookie的支持;
◆加入ActiveXObject類擴展BOM,通過JavaScript實例化ActiveX對象。

BOM有一些事實上的標準,如窗口對象、導航對象等,但每種瀏覽器都為這些對象定義或擴展了屬性及方法。Document Object Model,這個就是標準了,由著名的w3c制定,目前***的級別是level 3,不過3還沒有徹底完成。

目前主流的瀏覽器都可以支持到(僅僅是支持到哦,并不是完全遵守的)level 2,對html,也就是html4.x,目前***的是4.01,后來w3c向把html統一向xml靠攏,于是就有了xhtml1.0,再后來,w3c想搞一個xhtml2.0,結果進度緩慢,加之各大廠商又不看好,于是就有了html5.0

1、創建節點

  1. createElement():   
  2. var a  = document.createElement(“p”);  

它創建的是一個元素節點,所以nodeType等于1,a.nodeName將返回p。

注意;createElement()方法創建出來的新元素節點不會被自動添加到文檔里,既然沒添加到文檔里,說明它還是一個游離的狀態。所以它也沒有nodeParent屬性。如果想把它添加到文檔里,可以使用 appendChild()或者insertBefore()方法或者replaceChild()方法。當然我們在前面的例子中,自己寫了一個 insertAfter()方法,比如:

  1. var a  = document.createElement(“p”);   
  2. document.body.appendChild(a);  

注意: appendChild()默認是添加到文檔的***。也就是lastChild子節點。如果想添加到某個地方,可以使用insertBefore()。如果想在元素插入之前給元素添加屬性。可以這么做:

  1. var a  = document.createElement(“p”);   
  2. a.setAttribute(“title”,”my demo”);   
  3. document.body.appendChild(a);   
  4. createTextNode():   
  5. var b = document.createTextNode(“my demo”);  

它創建的是一個文本節點,所以nodeType等于3 。b.nodeName 將返回 #text ; 跟createElement()一樣,用createTextNode()創建的節點也不會自動添加到文檔里。需要使用 appendChild()或者insertBefore()方法或者replaceChild()方法。它經常與createElement()配合使用,知道為什么嗎?(一個元素節點,一個文本節點。)

  1. var mes = document.createTextNode(“hello world”);   
  2. var container = document.createElement(“p”);   
  3. container.appendChild(mes);   
  4. document.body.appendChild(container);  

2、復制節點

cloneNode(boolean):

  1. var mes = document.createTextNode("hello world");   
  2. var container = document.createElement("p");   
  3. container.appendChild(mes);   
  4. document.body.appendChild(container);   
  5. var newpara = container.cloneNode(true);//true和false的區別   
  6. document.body.appendChild(newpara );  

注意:
 
◆true的話:是<p>aaaa</p>克隆。
◆false: 只克隆 <p></p>,里面的文本不克隆。
◆可以自己寫個例子,然后用firebug看看。

克隆后的新節點,和createTextNode()一樣  不會被自動插入到文檔 。需要appendChild();另外還有一個注意: 如果克隆后,id一樣,不要忘記用 setAttribute(“id” , “ another_id “);改變新的節點的ID。

#p#

3、插入節點

appendChild() :

  1. var container = document.createElement("p");   
  2. var t =  document.createTextNode("cssrain");   
  3. container.appendChild(t);   
  4. document.body.appendChild(container);  

它經常跟createElement()和createTextNode(),cloneNode()配合使用。另外appendChild()不僅可以用來追加新的元素,也可以你挪動文檔中現有的元素。看下面的例子:

  1. <p id="msg">msg</p>   
  2. <p id="content">content</p>   
  3. <p id="aaa">aaaaaaaa</p>   
  4. <script>   
  5. var mes = document.getElementById("msg");   
  6. var container = document.getElementById("content");   
  7. container.appendChild(mes);   
  8. </script>   
  9. //發現msg放到 content 后面去了。  
  10. <p id="content">   
  11. content   
  12. <p id="msg">msg</p>   
  13. </p>   
  14. <p id="aaa">aaaaaaaa</p>  

第二個參數是可選,如果第二個參數不寫,將默認添加到文檔的***,相當于appendChild();我們看看insertBefore()怎么使用:

  1. <div id="cssrian">   
  2. <p id="content">1111</p>   
  3. <div id="msg">msg<div>test</div></div>   
  4. <p id="content">222</p>   
  5. <p id="aaa">aaaaaaaa</p>   
  6. </div>   
  7. <script>   
  8. var msg = document.getElementById("msg");   
  9. var aaa = document.getElementById("aaa");   
  10. var test = document.getElementById("cssrian");   
  11. test.insertBefore( msg , aaa );   
  12. </script>   
  13. // 我們發現ID為msg的 插入到了aaa的前面。 

Js內部處理方式跟 appendChild()相似。

4、刪除節點

removeChild():

  1. <body>   
  2. <div id="cssrain">   
  3. <div id="a"></div>   
  4. <div id="b"></div>   
  5. <div id="c"></div>   
  6. </div>   
  7. </body>   
  8. <script>   
  9. var msg = document.getElementById("cssrain");   
  10. var b = document.getElementById("b");   
  11. msg.removeChild(b);   
  12. </script>  

如果不知道要刪除的節點的父節點是什么?可以使用parentNode屬性。比如:

  1. <body>   
  2. <div id="cssrain">   
  3. <div id="a"></div>   
  4. <div id="b"></div>   
  5. <div id="c"></div>   
  6. </div>   
  7. </body>   
  8. <script>   
  9. var b = document.getElementById("b");   
  10. var c = b.parentNode;   
  11. c.removeChild(b);   
  12. </script>  

注意:你如果想把某個節點從一處移動到另一個地方,不必使用removeChild()。可以使用前面的 appendChild()和insertBefore(),他們都會自動先刪除節點,然后移動到你指定的地方。、

5、替換節點

  1. Element.repalceChild( newNode , oldNode ):  
  2.  
  3. <body>   
  4. <div id="cssrain">   
  5. <div id="a"></div>   
  6. <div id="b"></div>   
  7. <div id="c"></div>   
  8. </div>   
  9. </body>   
  10. <script>   
  11. var cssrain = document.getElementById("cssrain");   
  12. var msg =  document.getElementById("b");   
  13. var para =  document.createElement("p");   
  14. cssrain.replaceChild( para , msg  );   
  15. </script>  

#p#

6、設置/獲取屬性節點

  1. setAttribute();//設置   
  2.  
  3. var a  = document.createElement(“p”);   
  4. a.setAttribute(“title”,”my demo”);   
  5.  
  6. var a =document.getElementById(“cssrain”);   
  7. var b = a.getAttribute(“title”);  

獲取的時候,如果屬性不存在,則返回空,注意ie和ff返回不同,可以看我以前的例子。 返回雖然不同,但是可以用一個方法來判斷:if(a.getAttribute(“title”) ){   }

7、查找節點

getElementById();

返回一個對象,對象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。getElementsByTagName():查找標簽名的所有元素。返回一個集合,可以用循環取出每個對象,對象擁有 nodeName , nodeType , parentNode , ChildNodes 等屬性。 例子:

  1. var ps = document.getElementsByTagName(“p”);   
  2. for(var i=0 ; i< ps.length ; i++){   
  3.  ps[i].setAttribute(“title”,”hello”);   
  4. //也可以使用:  ps.item(i).setAttribute("title","hello");   
  5. }   
  6.    
  7. <body>   
  8. <div id="cssrain">   
  9. <div id="a"></div>   
  10. <div id="b"></div>   
  11. <div id="c"></div>   
  12. </div>   
  13. </body>   
  14. <script>   
  15. var ps = document.getElementById("cssrain")   
  16. if(ps.hasChildNodes){   
  17.         alert( ps.childNodes.length  );     
  18. }   
  19. </script>  

8、DOM屬性

我們常用的3中類型:
 
nodeType == 1  : 元素節點
nodeType == 2  : 屬性節點
nodeType == 3  : 文本節點

如果想記住的話,上面的順序我們可以看做是從前到后。比如:<p  title="cssrain" >test</p> 從前往后讀:你會發現先是元素節點,然后是屬性節點,***是文本節點,這樣你就很容易記住了nodeType分別代表什么類型了。nodeType屬性經常跟if配合使用,以確保不會在錯誤的節點類型上執行錯誤的操作。比如:

  1. function cs_demo(mynode){   
  2.       if(mynode.nodeType == 1){   
  3.               mynode.setAttribute("title","demo");   
  4.         }   
  5. }  

代碼解釋:先檢查mynode的nodeType屬性,以確保它所代表的節點確實是一個元素節點。和nodeName屬性一樣,他也是只讀屬性,不能進行設置.

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4. alert(  c.nodeValue  );//返回null   
  5. </SCRIPT>  

nodeValue是一個可以讀、寫的屬性。 但它不能設置元素節點的值。看下面的例子:

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4.   c.nodeValue =" dddddddddddd"; //不能設置   
  5.   //alert( c.firstChild.nodeValue ) //元素節點 包括屬性節點和文本節點。   
  6.   c.firstChild.nodeValue =  "test"//能設置   
  7. </SCRIPT>  

當然我們為了確保能正確運行:可以加一段代碼:

  1. <div id="c">aaaaaaaaaaaaaaaa</div>   
  2. <SCRIPT LANGUAGE="JavaScript">   
  3. var cdocument.getElementById("c");   
  4.   c.nodeValue =" dddddddddddd"; //不能設置   
  5.   //alert( c.firstChild.nodeValue )   
  6.   if( c.firstChild.nodeType==3 ){ //判斷是不是 文本節點   
  7.   c.firstChild.nodeValue =  "test"//能設置   
  8.   }   
  9. </SCRIPT>  

nodeValue一般只用來設置 文本節點的值。如果要刷新屬性節點的值,一般使用setAttribute(). childNodes屬性:返回一個數組,數組由元素節點的子節點構成。由于文本節點和屬性節點都不可能再包含任何子節點,所以他們的childNodes屬性永遠返回一個空數組。

可以使用hasChildNodes方法,它用來判斷某個元素有沒有子節點。或者if (container.childNodes.length < 1) ;childNodes也是一個只讀屬性。如果要增加節點,可以使用appendChild()或者insertBefore() ,刪除節點可以使用removeChild(); 操作后,childNodes屬性會自動刷新。

firstChild屬性

由于文本節點和屬性節點都不可能再包含任何子節點,所以他們的firstChild屬性永遠返回一個空數組。 如果沒有子節點,將返回null;node.firstChild 等價于  node.childNodes[0] ; firstChild屬性是一個只讀屬性。

lastChild屬性

由于文本節點和屬性節點都不可能再包含任何子節點,所以他們的lastChild屬性永遠返回一個空數組。 如果沒有子節點,將返回null; node.lastChild  等價于  node.childNodes[ node.childNodes.length - 1 ] ;lastChild屬性是一個只讀屬性。

nextSibling屬性

返回目標節點的下一個兄弟節點。如果目標節點后面沒有同屬于一個父節點的節點,nextSibling 將返回null ;nextSibling 屬性是一個只讀屬性。

previousSibling屬性

返回目標節點的前一個兄弟節點。如果目標節點前面沒有同屬于一個父節點的節點,previousSibling 將返回null ;previousSibling 屬性是一個只讀屬性。

parentNode屬性

注:parentNode屬性返回的節點永遠是一個元素節點,因為只有元素節點才有可能有子節點。

當然有個例外

document節點,他沒有父節點。所以document節點的parentNode屬性將返回null;parentNode 屬性是一個只讀屬性。
 

【編輯推薦】

  1. JavaScript使用心得匯總:從BOM和DOM談起
  2. 關于使用JavaScript的幾點建議
  3. 早該知道的7個JavaScript技巧
責任編輯:王曉東 來源: 博客園
相關推薦

2009-08-26 13:31:21

JavaScript使

2021-09-09 10:26:26

Javascript 文檔對象前端

2010-09-28 14:35:34

DOM遍歷

2010-09-28 09:14:36

HTML DOMJavascript

2011-01-18 14:06:58

JavaScriptweb

2011-07-04 13:12:04

JavaScript

2015-12-24 10:05:39

JavaScripttypeofinstanceof

2024-11-07 09:08:58

2010-09-28 12:59:45

JavaScriptDOM

2010-08-17 15:04:37

JavaScriptDOM ready

2010-09-08 16:50:11

JavaScriptDOM操作

2010-09-08 15:13:09

Node節點Node屬性

2010-09-28 14:12:50

Javascript

2010-09-08 17:26:46

JavaScript

2009-12-15 14:16:13

Ruby Contin

2023-05-12 08:11:58

JavaScriptJSON克隆

2021-02-05 07:33:05

JavaScript參數ES6

2010-09-28 13:24:34

DOM文檔對象模型

2010-09-28 09:22:34

DOM模型Html

2016-04-06 11:29:58

JavaScriptDOM操作
點贊
收藏

51CTO技術棧公眾號

国产亚洲成aⅴ人片在线观看| 天堂美国久久| 色综合夜色一区| 色姑娘综合网| 精品国产av一区二区三区| 亚洲高清激情| 色久欧美在线视频观看| 精人妻一区二区三区| 亚洲成人人体| 亚洲精品成人精品456| 蜜桃导航-精品导航| 136福利视频导航| 中文欧美日韩| 久久精品国产久精国产思思| 日本黄色录像片| 久草综合在线| 欧美日韩视频免费播放| 在线观看亚洲视频啊啊啊啊| 免费国产羞羞网站视频| 麻豆精品一区二区综合av| 亚州av一区二区| 卡通动漫亚洲综合| 九一国产精品| 亚洲精品一区二区三区在线观看 | 无码av免费精品一区二区三区| 在线精品亚洲欧美日韩国产| 亚洲综合网站在线观看| 夜夜爽99久久国产综合精品女不卡 | 国产中文字幕在线视频| 国产91富婆露脸刺激对白| 国产精品美女午夜av| 天天操天天干视频| 激情婷婷亚洲| 欧美另类高清videos| 手机毛片在线观看| 要久久电视剧全集免费| 亚洲成人精品视频在线观看| 国产精品久久久久久久av福利| 成人爽a毛片免费啪啪| 亚洲午夜羞羞片| 日本xxxxx18| 自拍视频在线播放| 久久丝袜美腿综合| 久久手机视频| 亚洲欧洲视频在线观看| 国产成人aaa| 2022国产精品| 国产av精国产传媒| 国产在线一区观看| 国产在线视频不卡| 国产精品国产一区二区三区四区 | 自拍亚洲一区| 日韩成人在线播放| 日韩精品人妻中文字幕有码| 综合成人在线| 欧美成人在线直播| 免费在线观看日韩av| 日韩免费精品| 欧美大片免费久久精品三p| 久久黄色一级视频| 亚洲精品一区二区三区在线| 欧美不卡一区二区三区四区| 初高中福利视频网站| www.国产精品一区| 亚洲国产欧美久久| 亚洲天堂久久新| 视频一区欧美| 综合网中文字幕| 亚洲精品天堂网| 中文精品久久| 久久久久久久久久亚洲| 一级片中文字幕| 三级亚洲高清视频| 91在线|亚洲| 亚洲精品97久久中文字幕| 成人午夜免费视频| 欧美精品一区二区三区在线看午夜 | 潘金莲一级黄色片| 一区二区日韩欧美| 久久久亚洲欧洲日产国码aⅴ| 日本va欧美va国产激情| 久久综合亚州| 成人网在线免费观看| 亚洲经典一区二区| 久久精品一区二区三区av | 中文字幕一区二区三区在线视频 | 老司机午夜精品| 亚洲综合最新在线| 亚洲人午夜射精精品日韩| 久久久午夜电影| 在线综合视频网站| 超碰高清在线| 欧美日韩在线亚洲一区蜜芽| 成人一区二区三区仙踪林| 噜噜噜天天躁狠狠躁夜夜精品| 亚洲深夜福利视频| 欧美日韩精品一区二区三区视频播放| 国产日韩欧美| 亚洲精品免费av| 青青视频在线观| 亚洲视频免费在线| 播放灌醉水嫩大学生国内精品| 国产成人免费| 亚洲第一黄色网| 色偷偷男人天堂| 亚洲精品综合| 国产日韩欧美夫妻视频在线观看| 亚洲精品成人电影| 国产精品进线69影院| www.日本在线播放| a一区二区三区亚洲| 亚洲精品福利在线| 九九视频在线观看| 麻豆国产精品一区二区三区| 精品伊人久久大线蕉色首页| 黄色网址在线免费观看| 色综合久久天天综合网| 免费高清视频在线观看| 欧美丝袜丝交足nylons172| 国内精品久久久| 国产美女www爽爽爽视频| 久久九九国产精品| www.com毛片| 久久精品国产亚洲blacked| 精品国产自在精品国产浪潮 | 欧美性xxxxxxxx| 国产 xxxx| 午夜国产精品视频| 国产日产欧美a一级在线| 国产中文字幕在线播放| 亚洲福利电影网| 99热这里只有精品2| 欧美一区二区性| 欧美自拍视频在线观看| 国内爆初菊对白视频| 亚洲精品欧美综合四区| 手机版av在线| 手机在线一区二区三区| 国产精品极品尤物在线观看| 你懂的视频在线观看| 欧美日韩国产一区在线| 亚洲熟女一区二区三区| 欧美视频久久| 国产精品久久久久久久久久直播| caoporm免费视频在线| 91麻豆精品国产91久久久久| 人与动物性xxxx| 久久se这里有精品| 亚洲视频在线二区| 亚洲精品三区| 久久精品国产久精国产一老狼| 97精品人妻一区二区三区在线| 亚洲国产精华液网站w| 欧美精品性生活| 成人网18免费网站| 国产日韩精品在线播放| 精品自拍一区| 日韩精品一区二区三区蜜臀| 国产午夜精品一区二区理论影院 | 人妻少妇精品视频一区二区三区| 欧美三区在线| 鬼打鬼之黄金道士1992林正英| 四季久久免费一区二区三区四区| 日韩欧美久久久| 国产精品suv一区二区| 91丨九色丨蝌蚪富婆spa| 国产极品美女高潮无套久久久| 国产在视频线精品视频www666| 国产精品www网站| 色老头视频在线观看| 91精品国产综合久久精品app| 中文字幕亚洲欧美日韩| 风间由美性色一区二区三区 | 免费中文日韩| 成人va天堂| 精品国内自产拍在线观看| 亚洲精品久久久狠狠狠爱| 精品女同一区二区三区在线播放| 日韩在线免费观看av| 日韩国产一区二| 免费看av软件| 卡通动漫国产精品| 国产精品va在线播放| 国产在线观看av| 亚洲第一视频网站| 欧美 亚洲 另类 激情 另类| 亚洲免费毛片网站| 亚洲国产欧美视频| 国产美女久久久久| 97国产精东麻豆人妻电影| 成人午夜国产| 国产日韩在线一区二区三区| 成人线上视频| 欧美精品在线网站| 国产中文在线| 日韩欧美国产麻豆| 91porny九色| 一区二区三区在线高清| 欧美熟妇激情一区二区三区| 国产精品综合网| 午夜精品久久久内射近拍高清| 亚洲国产精品久久久天堂 | 国产精品久久久久国产a级| h视频在线免费观看| 日韩精品免费在线视频观看| 国产精品九九九九| 在线免费一区三区| 天天插天天操天天干| 国产精品高潮呻吟久久| 国产精品无码一区二区三| 激情欧美日韩一区二区| 国产精品欧美激情在线观看| 欧美91大片| 亚洲综合欧美日韩| 国产欧美日韩精品一区二区免费 | 激情 小说 亚洲 图片: 伦| 国内视频精品| 一区二区高清视频| 蜜桃一区二区三区| 精品久久久久久亚洲| 日韩视频1区| 国产原创欧美精品| 欧美色网在线| 欧美专区中文字幕| av电影在线地址| 欧美精品一区在线播放| 麻豆传媒在线完整视频| 中文字幕精品网| 免费福利在线视频| 精品视频中文字幕| 天天综合网天天综合| 欧美videofree性高清杂交| 国产又粗又黄又爽| 欧美日韩激情一区二区三区| 亚洲欧美一二三区| 色视频成人在线观看免| 成年人视频在线免费看| 精品国产老师黑色丝袜高跟鞋| 国产精品日日夜夜| 亚洲国产视频直播| 免费看一级一片| 夜夜夜精品看看| 久久精品美女视频| 亚洲成av人片一区二区| 国产精品suv一区二区| 亚洲国产人成综合网站| 久久精品国产亚洲AV无码麻豆 | 在线视频一区二区| 黄色的视频在线免费观看| 亚洲女人天堂网| 久久精品a一级国产免视看成人| 日韩精品中文字幕有码专区| 污污视频在线观看网站| 亚洲男人天堂久| 国产在线视频福利| 中文字幕在线国产精品| jizz在线免费观看| 久久成人亚洲精品| 欧美日韩色网| 91成品人片a无限观看| 亚洲精华液一区二区三区| 欧美在线xxx| 欧美日韩在线精品一区二区三区激情综合 | 国产精品国产精品88| 亚洲猫色日本管| 久视频在线观看| 精品久久久久久中文字幕大豆网| 一级片中文字幕| 欧美无砖专区一中文字| 97超碰中文字幕| 精品国产乱码久久久久久免费| 午夜影院免费体验区| 在线看欧美日韩| 中文字幕伦理免费在线视频| 午夜剧场成人观在线视频免费观看| 美女扒开腿让男人桶爽久久软| 日韩美女在线观看| 国产在线视频欧美一区| 久久狠狠久久综合桃花| 久久性感美女视频| 日韩 欧美 视频| 日韩影院在线观看| 国产精品久久久久久久99| 9l国产精品久久久久麻豆| 日韩视频在线观看免费视频| 一区二区三区蜜桃| 好看的av在线| 欧美另类一区二区三区| 免费a级片在线观看| 正在播放欧美视频| 成年网站在线视频网站| 国产成人中文字幕| 136国产福利精品导航网址应用| 久久影视中文粉嫩av| 综合激情网站| 999香蕉视频| 国产成人亚洲综合a∨婷婷图片| 少妇户外露出[11p]| 综合亚洲深深色噜噜狠狠网站| 日韩欧美不卡视频| 91精品国产福利在线观看| 亚洲日本香蕉视频| 欧美精品一区二区三区国产精品| 伊人久久国产| 国产激情一区二区三区在线观看| 国产成人精品999在线观看| 国产爆乳无码一区二区麻豆| 日本中文字幕一区二区有限公司| 性猛交╳xxx乱大交| 国产精品麻豆一区二区| 五月天婷婷久久| 欧美成人激情免费网| 午夜不卡视频| 国产aⅴ夜夜欢一区二区三区 | 日韩午夜av电影| sese一区| 日本成人在线视频网址| 澳门成人av| 强开小嫩苞一区二区三区网站| 久久精品九九| 久久久久麻豆v国产精华液好用吗| 综合久久久久综合| 中国女人真人一级毛片| 亚洲人成啪啪网站| 极品在线视频| 国产69精品久久久久9999apgf | 欧美精品免费在线观看| 成人午夜在线| 欧美色图亚洲自拍| 亚洲制服少妇| 天天插天天射天天干| 亚洲图片欧美视频| 性欧美8khd高清极品| 久久精品最新地址| 日韩第二十一页| 亚洲精品日韩在线观看| 日韩影院在线观看| 无码少妇精品一区二区免费动态| 精品久久久久久国产91| 五月婷婷深深爱| 91精品国产91久久久久久久久| 超碰成人免费| 欧美一级片免费播放| 高清在线观看日韩| 久久精品国产亚洲av香蕉| 欧美精品一区二区久久久| 1234区中文字幕在线观看| 国产伦精品一区二区三| 亚洲国产精品一区制服丝袜| 李丽珍裸体午夜理伦片| 亚洲成人在线观看视频| 天堂网在线资源| 中文字幕一区二区三区在线视频| 91在线视频一区| 性欧美欧美巨大69| 免费网站在线观看黄| 亚洲女同女同女同女同女同69| 国产毛片久久久久| 欧美日韩国产成人| 开心激情综合| 日韩中文字幕三区| 国产午夜精品久久久久久免费视 | 欧美日韩国产另类不卡| 黄网页在线观看| 国产精品二区二区三区| 日韩一级在线| 成人黄色免费网址| 欧美精品v国产精品v日韩精品| 麻豆视频在线播放| 岛国视频一区免费观看| 亚洲一区成人| xxxxx99| 日韩欧美的一区二区| 人人草在线视频| 色一情一乱一伦一区二区三区丨| 看电视剧不卡顿的网站| 日本aⅴ在线观看| 日韩激情片免费| av在线播放一区| 人人妻人人澡人人爽欧美一区| 暴力调教一区二区三区| 日韩免费av网站| 久久影视电视剧免费网站清宫辞电视 | 色综合久久久网| 日本暖暖在线视频| 国产精品传媒毛片三区| 全部av―极品视觉盛宴亚洲| 多男操一女视频| 日韩高清免费在线| 激情视频亚洲| 国产aaa一级片| 亚洲欧美偷拍三级| 精品亚洲成a人片在线观看| 91亚洲精品久久久| 亚洲电影有码| 日韩成人在线视频网站| 久久国产精品黑丝| 视频二区一区| av毛片久久久久**hd| 亚洲最新av网站|