日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > java >内容正文

java

【repost】Javascript操作DOM常用API总结

發(fā)布時(shí)間:2025/3/15 java 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【repost】Javascript操作DOM常用API总结 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Javascript操作DOM常用API總結(jié)

文本整理了javascript操作DOM的一些常用的api,根據(jù)其作用整理成為創(chuàng)建,修改,查詢等多種類型的api,主要用于復(fù)習(xí)基礎(chǔ)知識(shí),加深對原生js的認(rèn)識(shí)。

基本概念

在講解操作DOM的api之前,首先我們來復(fù)習(xí)一下一些基本概念,這些概念是掌握api的關(guān)鍵,必須理解它們。

Node類型

DOM1級定義了一個(gè)Node接口,該接口由DOM中所有節(jié)點(diǎn)類型實(shí)現(xiàn)。這個(gè)Node接口在JS中是作為Node類型實(shí)現(xiàn)的。在IE9以下版本無法訪問到這個(gè)類型,JS中所有節(jié)點(diǎn)都繼承自Node類型,都共享著相同的基本屬性和方法。
Node有一個(gè)屬性nodeType表示Node的類型,它是一個(gè)整數(shù),其數(shù)值分別表示相應(yīng)的Node類型,具體如下:
Node.ELEMENT_NODE:1
Node.ATTRIBUTE_NODE:2
Node.TEXT_NODE:3
Node.CDATA_SECTION_NODE:4
Node.ENTITY_REFERENCE_NODE:5
Node.ENTITY_NODE:6
Node.PROCESSING_INSTRUCTION_NODE:7
Node.COMMENT_NODE:8
Node.DOCUMENT_NODE:9
Node.DOCUMENT_TYPE_NODE:10
Node.DOCUMENT_FRAGMENT_NODE:11
Node.NOTATION_NODE:12
假設(shè)我們要判斷一個(gè)Node是不是元素,我們可以這樣判斷

1 if(someNode.nodeType == 1){ 2 console.log("Node is a element"); 3 }

這些Node類型中,我們最常用的就是element,text,attribute,comment,document,document_fragment這幾種類型。
我們簡單來介紹一下這幾種類型:

Element類型

Element提供了對元素標(biāo)簽名,子節(jié)點(diǎn)和特性的訪問,我們常用HTML元素比如div,span,a等標(biāo)簽就是element中的一種。Element有下面幾條特性:
(1)nodeType為1
(2)nodeName為元素標(biāo)簽名,tagName也是返回標(biāo)簽名
(3)nodeValue為null
(4)parentNode可能是Document或Element
(5)子節(jié)點(diǎn)可能是Element,Text,Comment,Processing_Instruction,CDATASection或EntityReference

Text類型

Text表示文本節(jié)點(diǎn),它包含的是純文本內(nèi)容,不能包含html代碼,但可以包含轉(zhuǎn)義后的html代碼。Text有下面的特性:
(1)nodeType為3
(2)nodeName為#text
(3)nodeValue為文本內(nèi)容
(4)parentNode是一個(gè)Element
(5)沒有子節(jié)點(diǎn)

Attr類型

Attr類型表示元素的特性,相當(dāng)于元素的attributes屬性中的節(jié)點(diǎn),它有下面的特性:
(1)nodeType值為2
(2)nodeName是特性的名稱
(3)nodeValue是特性的值
(4)parentNode為null

Comment類型

Comment表示HTML文檔中的注釋,它有下面的幾種特征:
(1)nodeType為8
(2)nodeName為#comment
(3)nodeValue為注釋的內(nèi)容
(4)parentNode可能是Document或Element
(5)沒有子節(jié)點(diǎn)

Document

Document表示文檔,在瀏覽器中,document對象是HTMLDocument的一個(gè)實(shí)例,表示整個(gè)頁面,它同時(shí)也是window對象的一個(gè)屬性。Document有下面的特性:
(1)nodeType為9
(2)nodeName為#document
(3)nodeValue為null
(4)parentNode為null
(5)子節(jié)點(diǎn)可能是一個(gè)DocumentType或Element

DocumentFragment類型

DocumentFragment是所有節(jié)點(diǎn)中唯一一個(gè)沒有對應(yīng)標(biāo)記的類型,它表示一種輕量級的文檔,可能當(dāng)作一個(gè)臨時(shí)的倉庫用來保存可能會(huì)添加到文檔中的節(jié)點(diǎn)。DocumentFragment有下面的特性:
(1)nodeType為11
(2)nodeName為#document-fragment
(3)nodeValue為null
(4)parentNode為null

我們簡單地介紹了幾種常見的Node類型,要記住,HTML中的節(jié)點(diǎn)并不只是包括元素節(jié)點(diǎn),它還包括文本節(jié)點(diǎn),注釋節(jié)點(diǎn)等等。在這里我們只是簡單地說明了幾種常見的節(jié)點(diǎn),想要進(jìn)一步學(xué)習(xí)的同學(xué)可以查找一下相關(guān)資料。

節(jié)點(diǎn)創(chuàng)建型api

在這里,我將常用的DOM操作api進(jìn)行分類,首先要介紹的是創(chuàng)建型的api。這一類型的api,簡而言之就是用來創(chuàng)建節(jié)點(diǎn)的。

createElement

createElement通過傳入指定的一個(gè)標(biāo)簽名來創(chuàng)建一個(gè)元素,如果傳入的標(biāo)簽名是一個(gè)未知的,則會(huì)創(chuàng)建一個(gè)自定義的標(biāo)簽,注意:IE8以下瀏覽器不支持自定義標(biāo)簽。
使用如下:

var div = document.createElement("div");

使用createElement要注意:通過createElement創(chuàng)建的元素并不屬于html文檔,它只是創(chuàng)建出來,并未添加到html文檔中,要調(diào)用appendChild或insertBefore等方法將其添加到HTML文檔樹中。

createTextNode

createTextNode用來創(chuàng)建一個(gè)文本節(jié)點(diǎn),用法如下:

1 var textNode = document.createTextNode("一個(gè)TextNode");

createTextNode接收一個(gè)參數(shù),這個(gè)參數(shù)就是文本節(jié)點(diǎn)中的文本,和createElement一樣,創(chuàng)建后的文本節(jié)點(diǎn)也只是獨(dú)立的一個(gè)節(jié)點(diǎn),同樣需要appendChild將其添加到HTML文檔樹中

cloneNode

cloneNode是用來返回調(diào)用方法的節(jié)點(diǎn)的一個(gè)副本,它接收一個(gè)bool參數(shù),用來表示是否復(fù)制子元素,使用如下:

1 var parent = document.getElementById("parentElement"); 2 var parent2 = parent.cloneNode(true);// 傳入true 3 parent2.id = "parent2";

這段代碼通過cloneNode復(fù)制了一份parent元素,其中cloneNode的參數(shù)為true,表示parent的子節(jié)點(diǎn)也被復(fù)制,如果傳入false,則表示只復(fù)制了parent節(jié)點(diǎn)。
我們看看這個(gè)例子

1 <div id="parent">2 我是父元素的文本3 <br/>4 <span>5 我是子元素6 </span>7 </div>8 <button id="btnCopy">復(fù)制</button>9 10 var parent = document.getElementById("parent"); 11 document.getElementById("btnCopy").onclick = function(){ 12 var parent2 = parent.cloneNode(true); 13 parent2.id = "parent2"; 14 document.body.appendChild(parent2); 15 }

這段代碼很簡單,主要是綁定button事件,事件內(nèi)容是復(fù)制了一個(gè)parent,修改其id,然后添加到文檔中。
這里有幾點(diǎn)要注意:
(1)和createElement一樣,cloneNode創(chuàng)建的節(jié)點(diǎn)只是游離有html文檔外的節(jié)點(diǎn),要調(diào)用appendChild方法才能添加到文檔樹中
(2)如果復(fù)制的元素有id,則其副本同樣會(huì)包含該id,由于id具有唯一性,所以在復(fù)制節(jié)點(diǎn)后必須要修改其id
(3)調(diào)用接收的bool參數(shù)最好傳入,如果不傳入該參數(shù),不同瀏覽器對其默認(rèn)值的處理可能不同

除此之外,我們還有一個(gè)需要注意的點(diǎn):
如果被復(fù)制的節(jié)點(diǎn)綁定了事件,則副本也會(huì)跟著綁定該事件嗎?這里要分情況討論:
(1)如果是通過addEventListener或者比如onclick進(jìn)行綁定事件,則副本節(jié)點(diǎn)不會(huì)綁定該事件
(2)如果是內(nèi)聯(lián)方式綁定比如

1 <div οnclick="showParent()"></div>

這樣的話,副本節(jié)點(diǎn)同樣會(huì)觸發(fā)事件。

createDocumentFragment

createDocumentFragment方法用來創(chuàng)建一個(gè)DocumentFragment。在前面我們說到DocumentFragment表示一種輕量級的文檔,它的作用主要是存儲(chǔ)臨時(shí)的節(jié)點(diǎn)用來準(zhǔn)備添加到文檔中。
createDocumentFragment方法主要是用于添加大量節(jié)點(diǎn)到文檔中時(shí)會(huì)使用到。假設(shè)要循環(huán)一組數(shù)據(jù),然后創(chuàng)建多個(gè)節(jié)點(diǎn)添加到文檔中,比如示例

1 <ul id="list"></ul>2 <input type="button" value="添加多項(xiàng)" id="btnAdd" />3 4 document.getElementById("btnAdd").onclick = function(){5 var list = document.getElementById("list");6 for(var i = 0;i < 100; i++){7 var li = document.createElement("li");8 li.textContent = i;9 list.appendChild(li); 10 } 11 }

這段代碼將按鈕綁定了一個(gè)事件,這個(gè)事件創(chuàng)建了100個(gè)li節(jié)點(diǎn),然后依次將其添加HTML文檔中。這樣做有一個(gè)缺點(diǎn):每次一創(chuàng)建一個(gè)新的元素,然后添加到文檔樹中,這個(gè)過程會(huì)造成瀏覽器的回流。所謂回流簡單說就是指元素大小和位置會(huì)被重新計(jì)算,如果添加的元素太多,會(huì)造成性能問題。這個(gè)時(shí)候,就是使用createDocumentFragment了。
DocumentFragment不是文檔樹的一部分,它是保存在內(nèi)存中的,所以不會(huì)造成回流問題。我們修改上面的代碼如下:

1 document.getElementById("btnAdd").onclick = function(){2 var list = document.getElementById("list"); 3 var fragment = document.createDocumentFragment();4 5 for(var i = 0;i < 100; i++){6 var li = document.createElement("li");7 li.textContent = i;8 fragment.appendChild(li);9 } 10 11 list.appendChild(fragment); 12 }

優(yōu)化后的代碼主要是創(chuàng)建了一個(gè)fragment,每次生成的li節(jié)點(diǎn)先添加到fragment,最后一次性添加到list,大家可以看示例

創(chuàng)建型API總結(jié)

創(chuàng)建型api主要包括createElement,createTextNode,cloneNode和createDocumentFragment四個(gè)方法,需要注意下面幾點(diǎn):
(1)它們創(chuàng)建的節(jié)點(diǎn)只是一個(gè)孤立的節(jié)點(diǎn),要通過appendChild添加到文檔中
(2)cloneNode要注意如果被復(fù)制的節(jié)點(diǎn)是否包含子節(jié)點(diǎn)以及事件綁定等問題
(3)使用createDocumentFragment來解決添加大量節(jié)點(diǎn)時(shí)的性能問題

頁面修改型API

前面我們提到創(chuàng)建型api,它們只是創(chuàng)建節(jié)點(diǎn),并沒有真正修改到頁面內(nèi)容,而是要調(diào)用appendChild來將其添加到文檔樹中。我在這里將這類會(huì)修改到頁面內(nèi)容歸為一類。
修改頁面內(nèi)容的api主要包括:appendChild,insertBefore,removeChild,replaceChild。

appendChild

appendChild我們在前面已經(jīng)用到多次,就是將指定的節(jié)點(diǎn)添加到調(diào)用該方法的節(jié)點(diǎn)的子元素的末尾。調(diào)用方法如下:

1 parent.appendChild(child);

child節(jié)點(diǎn)將會(huì)作為parent節(jié)點(diǎn)的最后一個(gè)子節(jié)點(diǎn)。
appendChild這個(gè)方法很簡單,但是還有有一點(diǎn)需要注意:如果被添加的節(jié)點(diǎn)是一個(gè)頁面中存在的節(jié)點(diǎn),則執(zhí)行后這個(gè)節(jié)點(diǎn)將會(huì)添加到指定位置,其原本所在的位置將移除該節(jié)點(diǎn),也就是說不會(huì)同時(shí)存在兩個(gè)該節(jié)點(diǎn)在頁面上,相當(dāng)于把這個(gè)節(jié)點(diǎn)移動(dòng)到另一個(gè)地方。我們來看例子

1 <div id="child">2 要被添加的節(jié)點(diǎn)3 </div>4 <br/>5 <br/>6 <br/>7 <div id="parent">8 要移動(dòng)的位置9 </div> 10 <input id="btnMove" type="button" value="移動(dòng)節(jié)點(diǎn)" /> 11 12 document.getElementById("btnMove").onclick = function(){ 13 var child = document.getElementById("child"); 14 document.getElementById("parent").appendChild(child); 15 }

這段代碼主要是獲取頁面上的child節(jié)點(diǎn),然后添加到指定位置,可以看到原本的child節(jié)點(diǎn)被移動(dòng)到parent中了。
這里還有一個(gè)要注意的點(diǎn):如果child綁定了事件,被移動(dòng)時(shí),它依然綁定著該事件。

insertBefore

insertBefore用來添加一個(gè)節(jié)點(diǎn)到一個(gè)參照節(jié)點(diǎn)之前,用法如下:

1 parentNode.insertBefore(newNode,refNode);

parentNode表示新節(jié)點(diǎn)被添加后的父節(jié)點(diǎn)
newNode表示要添加的節(jié)點(diǎn)
refNode表示參照節(jié)點(diǎn),新節(jié)點(diǎn)會(huì)添加到這個(gè)節(jié)點(diǎn)之前
我們來看這個(gè)例子

1 <div id="parent">2 父節(jié)點(diǎn)3 <div id="child"> 4 子元素5 </div>6 </div>7 <input type="button" id="insertNode" value="插入節(jié)點(diǎn)" />8 9 var parent = document.getElementById("parent"); 10 var child = document.getElementById("child"); 11 document.getElementById("insertNode").onclick = function(){ 12 var newNode = document.createElement("div"); 13 newNode.textContent = "新節(jié)點(diǎn)" 14 parent.insertBefore(newNode,child); 15 }

這段代碼創(chuàng)建了一個(gè)新節(jié)點(diǎn),然后添加到child節(jié)點(diǎn)之前。
和appendChild一樣,如果插入的節(jié)點(diǎn)是頁面上的節(jié)點(diǎn),則會(huì)移動(dòng)該節(jié)點(diǎn)到指定位置,并且保留其綁定的事件。

關(guān)于第二個(gè)參數(shù)參照節(jié)點(diǎn)還有幾個(gè)注意的地方:
(1)refNode是必傳的,如果不傳該參數(shù)會(huì)報(bào)錯(cuò)
(2)如果refNode是undefined或null,則insertBefore會(huì)將節(jié)點(diǎn)添加到子元素的末尾

removeChild

removeChild顧名思義,就是刪除指定的子節(jié)點(diǎn)并返回,用法如下:

1 var deletedChild = parent.removeChild(node);

deletedChild指向被刪除節(jié)點(diǎn)的引用,它等于node,被刪除的節(jié)點(diǎn)仍然存在于內(nèi)存中,可以對其進(jìn)行下一步操作。
注意:如果被刪除的節(jié)點(diǎn)不是其子節(jié)點(diǎn),則程序?qū)?huì)報(bào)錯(cuò)。我們可以通過下面的方式來確保可以刪除:

1 if(node.parentNode){ 2 node.parentNode.removeChild(node); 3 }

通過節(jié)點(diǎn)自己獲取節(jié)點(diǎn)的父節(jié)點(diǎn),然后將自身刪除。

replaceChild

replaceChild用于使用一個(gè)節(jié)點(diǎn)替換另一個(gè)節(jié)點(diǎn),用法如下

1 parent.replaceNode(newChild,oldChild);

?

newChild是替換的節(jié)點(diǎn),可以是新的節(jié)點(diǎn),也可以是頁面上的節(jié)點(diǎn),如果是頁面上的節(jié)點(diǎn),則其將被轉(zhuǎn)移到新的位置
oldChild是被替換的節(jié)點(diǎn)

頁面修改型API總結(jié)

頁面修改型api主要是這四個(gè)接口,要注意幾個(gè)特點(diǎn):
(1)不管是新增還是替換節(jié)點(diǎn),如果新增或替換的節(jié)點(diǎn)是原本存在頁面上的,則其原來位置的節(jié)點(diǎn)將被移除,也就是說同一個(gè)節(jié)點(diǎn)不能存在于頁面的多個(gè)位置
(2)節(jié)點(diǎn)本身綁定的事件會(huì)不會(huì)消失,會(huì)一直保留著。

節(jié)點(diǎn)查詢型API

節(jié)點(diǎn)查詢型API也是非常常用的api,下面我們分別說明一下每一個(gè)api的使用。

document.getElementById

這個(gè)接口很簡單,根據(jù)元素id返回元素,返回值是Element類型,如果不存在該元素,則返回null。
使用這個(gè)接口有幾點(diǎn)要注意:
(1)元素的Id是大小寫敏感的,一定要寫對元素的id
(2)HTML文檔中可能存在多個(gè)id相同的元素,則返回第一個(gè)元素
(3)只從文檔中進(jìn)行搜索元素,如果創(chuàng)建了一個(gè)元素并指定id,但并沒有添加到文檔中,則這個(gè)元素是不會(huì)被查找到的

document.getElementsByTagName

這個(gè)接口根據(jù)元素標(biāo)簽名獲取元素,返回一個(gè)即時(shí)的HTMLCollection類型,什么是即時(shí)的HTMLCollection類型呢?我們來看看這個(gè)示例

1 <div>div1</div>2 <div>div2</div>3 4 <input type="button" value="顯示數(shù)量" id="btnShowCount"/>5 <input type="button" value="新增div" id="btnAddDiv"/> 6 7 var divList = document.getElementsByTagName("div");8 document.getElementById("btnAddDiv").onclick = function(){9 var div = document.createElement("div"); 10 div.textContent ="div" + (divList.length+1); 11 document.body.appendChild(div); 12 } 13 14 document.getElementById("btnShowCount").onclick = function(){ 15 alert(divList.length); 16 }

這段代碼中有兩個(gè)按鈕,一個(gè)按鈕是顯示HTMLCollection元素的個(gè)數(shù),另一個(gè)按鈕可以新增一個(gè)div標(biāo)簽到文檔中。前面提到HTMLCollcetion元素是即時(shí)的表示該集合是隨時(shí)變化的,也就是是文檔中有幾個(gè)div,它會(huì)隨時(shí)進(jìn)行變化,當(dāng)我們新增一個(gè)div后,再訪問HTMLCollection時(shí),就會(huì)包含這個(gè)新增的div。
使用document.getElementsByTagName這個(gè)方法有幾點(diǎn)要注意:
(1)如果要對HTMLCollection集合進(jìn)行循環(huán)操作,最好將其長度緩存起來,因?yàn)槊看窝h(huán)都會(huì)去計(jì)算長度,暫時(shí)緩存起來可以提高效率
(2)如果沒有存在指定的標(biāo)簽,該接口返回的不是null,而是一個(gè)空的HTMLCollection
(3)“*”表示所有標(biāo)簽

document.getElementsByName

getElementsByName主要是通過指定的name屬性來獲取元素,它返回一個(gè)即時(shí)的NodeList對象。
使用這個(gè)接口主要要注意幾點(diǎn):
(1)返回對象是一個(gè)即時(shí)的NodeList,它是隨時(shí)變化的
(2)在HTML元素中,并不是所有元素都有name屬性,比如div是沒有name屬性的,但是如果強(qiáng)制設(shè)置div的name屬性,它也是可以被查找到的
(3)在IE中,如果id設(shè)置成某個(gè)值,然后傳入getElementsByName的參數(shù)值和id值一樣,則這個(gè)元素是會(huì)被找到的,所以最好不好設(shè)置同樣的值給id和name

document.getElementsByClassName

這個(gè)API是根據(jù)元素的class返回一個(gè)即時(shí)的HTMLCollection,用法如下

1 var elements = document.getElementsByClassName(names);

這個(gè)接口有下面幾點(diǎn)要注意:
(1)返回結(jié)果是一個(gè)即時(shí)的HTMLCollection,會(huì)隨時(shí)根據(jù)文檔結(jié)構(gòu)變化
(2)IE9以下瀏覽器不支持
(3)如果要獲取2個(gè)以上classname,可傳入多個(gè)classname,每個(gè)用空格相隔,例如

1 var elements = document.getElementsByClassName("test1 test2");

document.querySelector和document.querySelectorAll

這兩個(gè)api很相似,通過css選擇器來查找元素,注意選擇器要符合CSS選擇器的規(guī)則。
首先來介紹一下document.querySelector。
document.querySelector返回第一個(gè)匹配的元素,如果沒有匹配的元素,則返回null。
注意,由于返回的是第一個(gè)匹配的元素,這個(gè)api使用的深度優(yōu)先搜索來獲取元素。我們來看這個(gè)例子:

1 <div>2 <div>3 <span class="test">第三級的span</span> 4 </div>5 </div>6 <div class="test"> 7 同級的第二個(gè)div8 </div>9 <input type="button" id="btnGet" value="獲取test元素" /> 10 11 document.getElementById("btnGet").addEventListener("click",function(){ 12 var element = document.querySelector(".test"); 13 alert(element.textContent); 14 })

這個(gè)例子很簡單,就是兩個(gè)class都包含“test”的元素,一個(gè)在文檔樹的前面,但是它在第三級,另一個(gè)在文檔樹的后面,但它在第一級,通過querySelector獲取元素時(shí),它通過深度優(yōu)先搜索,拿到文檔樹前面的第三級的元素。

document.querySelectorAll的不同之處在于它返回的是所有匹配的元素,而且可以匹配多個(gè)選擇符,我們來看看下面這個(gè)例子

1 <div class="test">2 class為test3 </div>4 <div id="test">5 id為test6 </div>7 <input id="btnShow" type="button" value="顯示內(nèi)容" />8 9 document.getElementById("btnShow").addEventListener("click",function(){ 10 var elements = document.querySelectorAll("#test,.test"); 11 for(var i = 0,length = elements.length;i<length;i++){ 12 alert(elements[i].textContent); 13 } 14 })

這段代碼通過querySelectorAll,使用id選擇器和class選擇器選擇了兩個(gè)元素,并依次輸出其內(nèi)容。要注意兩點(diǎn):
(1)querySelectorAll也是通過深度優(yōu)先搜索,搜索的元素順序和選擇器的順序無關(guān)
(2)返回的是一個(gè)非即時(shí)的NodeList,也就是說結(jié)果不會(huì)隨著文檔樹的變化而變化

兼容性問題:querySelector和querySelectorAll在ie8以下的瀏覽器不支持。

節(jié)點(diǎn)關(guān)系型api

在html文檔中的每個(gè)節(jié)點(diǎn)之間的關(guān)系都可以看成是家譜關(guān)系,包含父子關(guān)系,兄弟關(guān)系等等,下面我們依次來看看每一種關(guān)系。

父關(guān)系型api

parentNode:每個(gè)節(jié)點(diǎn)都有一個(gè)parentNode屬性,它表示元素的父節(jié)點(diǎn)。Element的父節(jié)點(diǎn)可能是Element,Document或DocumentFragment。
parentElement:返回元素的父元素節(jié)點(diǎn),與parentNode的區(qū)別在于,其父節(jié)點(diǎn)必須是一個(gè)Element,如果不是,則返回null

兄弟關(guān)系型api

previousSibling:節(jié)點(diǎn)的前一個(gè)節(jié)點(diǎn),如果該節(jié)點(diǎn)是第一個(gè)節(jié)點(diǎn),則為null。注意有可能拿到的節(jié)點(diǎn)是文本節(jié)點(diǎn)或注釋節(jié)點(diǎn),與預(yù)期的不符,要進(jìn)行處理一下。
previousElementSibling:返回前一個(gè)元素節(jié)點(diǎn),前一個(gè)節(jié)點(diǎn)必須是Element,注意IE9以下瀏覽器不支持。

nextSibling:節(jié)點(diǎn)的后一個(gè)節(jié)點(diǎn),如果該節(jié)點(diǎn)是最后一個(gè)節(jié)點(diǎn),則為null。注意有可能拿到的節(jié)點(diǎn)是文本節(jié)點(diǎn),與預(yù)期的不符,要進(jìn)行處理一下。
nextElementSibling:返回后一個(gè)元素節(jié)點(diǎn),后一個(gè)節(jié)點(diǎn)必須是Element,注意IE9以下瀏覽器不支持。

子關(guān)系型api

childNodes:返回一個(gè)即時(shí)的NodeList,表示元素的子節(jié)點(diǎn)列表,子節(jié)點(diǎn)可能會(huì)包含文本節(jié)點(diǎn),注釋節(jié)點(diǎn)等。
children:一個(gè)即時(shí)的HTMLCollection,子節(jié)點(diǎn)都是Element,IE9以下瀏覽器不支持。
firstNode:第一個(gè)子節(jié)點(diǎn)
lastNode:最后一個(gè)子節(jié)點(diǎn)
hasChildNodes方法:可以用來判斷是否包含子節(jié)點(diǎn)。

元素屬性型api

setAttribute

setAttribute:根據(jù)名稱和值修改元素的特性,用法如下。

1 element.setAttribute(name, value);

其中name是特性名,value是特性值。如果元素不包含該特性,則會(huì)創(chuàng)建該特性并賦值。
如果元素本身包含指定的特性名為屬性,則可以世界訪問屬性進(jìn)行賦值,比如下面兩條代碼是等價(jià)的:

1 element.setAttribute("id","test"); 2 3 element.id = "test";

getAttribute

getAttribute返回指定的特性名相應(yīng)的特性值,如果不存在,則返回null或空字符串。用法如下:

1 var value = element.getAttribute("id");

元素樣式型api

window.getComputedStyle

window.getComputedStyle是用來獲取應(yīng)用到元素后的樣式,假設(shè)某個(gè)元素并未設(shè)置高度而是通過其內(nèi)容將其高度撐開,這時(shí)候要獲取它的高度就要用到getComputedStyle,用法如下:

1 var style = window.getComputedStyle(element[, pseudoElt]);

element是要獲取的元素,pseudoElt指定一個(gè)偽元素進(jìn)行匹配。
返回的style是一個(gè)CSSStyleDeclaration對象。
通過style可以訪問到元素計(jì)算后的樣式

getBoundingClientRect

getBoundingClientRect用來返回元素的大小以及相對于瀏覽器可視窗口的位置,用法如下:

1 var clientRect = element.getBoundingClientRect();

clientRect是一個(gè)DOMRect對象,包含left,top,right,bottom,它是相對于可視窗口的距離,滾動(dòng)位置發(fā)生改變時(shí),它們的值是會(huì)發(fā)生變化的。除了IE9以下瀏覽器,還包含元素的height和width等數(shù)據(jù),具體可查看鏈接

總結(jié)

本文主要總結(jié)了原生js中常用的操作DOM的api接口,主要為了復(fù)習(xí)基礎(chǔ)知識(shí)。平時(shí)開發(fā)用多了jQuery等類庫,對基礎(chǔ)知識(shí)的了解可能就漸漸地遺忘,但這些基礎(chǔ)知識(shí)才是我們立足的根本,只有掌握原生的js,才能真正做好js的開發(fā)。

原文地址:http://luopq.com/2015/11/30/javascript-dom/

2樓木的樹
好文,把高三那部分重新總結(jié)一遍,不錯(cuò)
1樓Ender.Lu
well done.thks

轉(zhuǎn)載于:https://www.cnblogs.com/neil080320/p/6281509.html

總結(jié)

以上是生活随笔為你收集整理的【repost】Javascript操作DOM常用API总结的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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

国产高清在线精品 | 亚洲欧美日韩国产一区二区 | 日日夜夜av | 二区三区毛片 | 九九热1 | 日韩一二三 | 亚洲精品资源在线 | 在线91视频 | 国模精品在线 | 激情视频在线高清看 | 成人91在线| 在线观看一级 | 五月的婷婷 | 国产在线中文 | 国产在线久草 | 手机在线欧美 | 99热手机在线观看 | 黄av免费 | 99精品在线直播 | 久久久免费观看视频 | 黄色a视频免费 | 在线免费视频 你懂得 | 狠狠狠狠狠干 | 日韩黄色中文字幕 | 99视频99 | 免费在线观看中文字幕 | 综合色亚洲 | 精品国产日本 | 91精品视频网站 | 在线看片一区 | 三日本三级少妇三级99 | 狠狠网 | 精品国产一区二区三区av性色 | 日本高清dvd | 国产涩涩网站 | 狠狠狠狠狠色综合 | 四虎在线免费视频 | 天天射天天做 | 国产精品k频道 | 最近高清中文字幕 | 999久久久欧美日韩黑人 | 久久视频中文字幕 | 热久久99这里有精品 | 天天天在线综合网 | 日日精品 | 精品一区二区亚洲 | 国产精品专区在线观看 | 人人藻人人澡人人爽 | 在线视频中文字幕一区 | 97精产国品一二三产区在线 | 免费看一及片 | 午夜精品久久 | 在线观看免费av片 | 99久久婷婷国产综合亚洲 | 国产精品久久久久久久免费观看 | 亚洲成av人影片在线观看 | 国产.精品.日韩.另类.中文.在线.播放 | 国产亚洲婷婷免费 | 黄a网| 日韩av午夜 | 久久久久欧美精品999 | 国产成人综合图片 | 天天天干夜夜夜操 | 国产成人av综合色 | 日韩免费在线 | 国产裸体永久免费视频网站 | 四虎成人精品永久免费av九九 | 日韩sese | 午夜性色 | 干 操 插 | 色综合久久综合 | 日韩精品免费一区二区三区 | 亚洲综合视频网 | 黄色精品久久 | 日本中文在线观看 | 久久夜色精品亚洲噜噜国4 午夜视频在线观看欧美 | 丁香高清视频在线看看 | 国产精品9999久久久久仙踪林 | 国产精品美女久久久免费 | 日韩三级免费观看 | 国产一级a毛片视频爆浆 | 一区三区视频 | 五月天视频网站 | av资源免费观看 | 玖玖爱免费视频 | 91九色网站 | 免费a级黄色毛片 | 日韩欧美国产免费播放 | 久久论理| 中文字幕影视 | 国产精品一区二区免费视频 | 婷婷亚洲综合五月天小说 | 婷婷av网| 成人小视频在线免费观看 | 久久一区国产 | 亚洲人成人99网站 | 五月天六月色 | 久久久99精品免费观看 | 最近免费中文字幕大全高清10 | 亚洲精品99| 97视频在线免费 | 婷婷激情小说网 | 日本精品视频在线播放 | 久草电影在线 | 国产第一页福利影院 | 在线观看国产成人av片 | 91精品国产一区 | 亚洲黄色一级电影 | 欧美一区二区视频97 | 99热精品久久 | 亚洲成a人片在线观看网站口工 | 欧美日韩国产在线精品 | 久久免费看a级毛毛片 | 国产日韩在线一区 | 亚洲精品在线二区 | 免费视频黄 | 天天综合五月天 | 婷婷久久一区 | 五月天,com| 在线中文字幕电影 | 日韩成人xxxx | bbbbb女女女女女bbbbb国产 | 亚洲国产精品va在线看黑人动漫 | 91大神在线观看视频 | 精品亚洲在线 | 精品在线免费观看 | 亚洲乱码国产乱码精品天美传媒 | 伊人国产在线观看 | av免费电影网站 | 日本69hd | av在线播放不卡 | 国产小视频你懂的在线 | 国产视频 亚洲视频 | 国产精品久久99综合免费观看尤物 | 亚洲国产欧洲综合997久久, | www.狠狠操| av在线一 | 欧美一级性生活片 | 日韩精品中文字幕在线播放 | 欧美俄罗斯性视频 | 日韩中文字 | 久艹在线播放 | 又湿又紧又大又爽a视频国产 | 在线免费观看视频一区 | 国产精品11 | 九九视频热 | 日韩欧美一区二区三区黑寡妇 | 天天在线免费视频 | av免费电影在线 | av成人免费在线观看 | 99精品视频在线观看视频 | 色综合久久五月天 | 黄色免费网站 | 一区二区三区四区不卡 | 国产一级一片免费播放放a 一区二区三区国产欧美 | 亚洲免费观看视频 | 中文字幕在线播放av | 欧美久久久久久久久久久久 | 亚洲九九九在线观看 | 六月丁香激情综合色啪小说 | 97热在线观看 | 337p日本大胆噜噜噜噜 | 亚洲国产精品一区二区久久hs | 国产麻豆精品传媒av国产下载 | 伊甸园av在线 | 欧美一级视频免费看 | 99久久久久国产精品免费 | 在线观看中文字幕av | 午夜精品久久久久久久久久久久久久 | 日韩在线视 | 黄色aaa级片 | 久久精品视频在线观看 | 在线看的毛片 | 欧美另类巨大 | 日韩精品电影在线播放 | 四虎永久精品在线 | 99久久精品日本一区二区免费 | av电影在线不卡 | 成人久久| 久草在线视频免费资源观看 | 国产精品成人aaaaa网站 | 久久视频网 | 在线看成人 | 日韩偷拍精品 | 国产精彩视频一区 | 免费高清av在线看 | 五月天综合 | 麻豆影视网站 | 亚洲欧美怡红院 | 亚洲精品国产精品国自产 | 超碰人人射 | 日韩午夜电影院 | 亚洲精品99久久久久久 | 麻豆传媒视频在线免费观看 | 久久久久亚洲a | 黄色在线成人 | 日批在线看 | 久艹视频免费观看 | 久久精品a | 91干干干| 97精品视频在线 | 国产裸体永久免费视频网站 | 久久久国产精品网站 | 久草视频免费在线播放 | 五月香视频在线观看 | 毛片精品免费在线观看 | 色欧美成人精品a∨在线观看 | 成人18视频| 精品视频成人 | 国产精品免费久久久久影院仙踪林 | 久久国产精品免费看 | 黄色a视频 | 久草在线综合网 | 啪啪激情网 | 中文字幕亚洲不卡 | 91丨九色丨国产在线观看 | www黄色大片 | 国产成人精品av久久 | 狠狠狠色狠狠色综合 | 亚洲国产欧洲综合997久久, | 91精品国产综合久久福利不卡 | 在线成人小视频 | 永久免费的啪啪网站免费观看浪潮 | www.午夜色.com | 日韩啪啪小视频 | 国产一区二区观看 | 麻花天美星空视频 | 欧美性色xo影院 | 中文字幕中文字幕在线中文字幕三区 | 欧美有色 | 在线观看涩涩 | 97超碰人人澡人人 | 日本精品一区二区在线观看 | 国产视频在线看 | 久久91久久久久麻豆精品 | 中文字幕久久精品 | 日本久久99| 亚洲影院国产 | 依人成人综合网 | 久草在线视频在线 | 亚洲成人av一区 | 十八岁以下禁止观看的1000个网站 | 日本3级在线观看 | 欧美伦理一区二区三区 | 99久久精品免费看国产免费软件 | 中文字幕视频三区 | 久久精品国产99 | 亚洲精品国精品久久99热 | av免费看网站 | 激情婷婷在线 | 精品久久国产 | 天天色官网 | 欧美日韩91 | 一级片色播影院 | 国产在线高清 | www.天天综合 | 在线视频亚洲 | 亚洲国产精品成人女人久久 | 成片免费观看视频大全 | 成年人免费观看在线视频 | 中文字幕av免费观看 | 国产精品日韩欧美一区二区 | 中文字幕一区二区三区乱码在线 | 久久99久久精品国产 | 亚洲免费视频在线观看 | 婷婷久操 | 国产精品麻豆三级一区视频 | a在线v| 伊人超碰在线 | 日韩精品第一区 | 欧美片一区二区三区 | 99精品影视 | 亚洲高清在线精品 | 一区二区三区动漫 | 91精品视频免费观看 | 999一区二区三区 | 婷婷丁香色综合狠狠色 | 香蕉久草 | 久久国产剧场电影 | 中文字幕第一页在线播放 | 久久精品视频网址 | 在线成人欧美 | 精品国产欧美一区二区 | 亚洲欧美日韩国产精品一区午夜 | 国产不卡一 | 国产黄色精品在线 | 三级av免费 | 欧美日韩不卡一区二区 | 国产一卡二卡在线 | av网址在线播放 | 中文字幕 国产精品 | 国产精品久久久久一区二区三区共 | www久久九| 在线电影中文字幕 | 91 在线视频播放 | 456成人精品影院 | 亚洲综合色丁香婷婷六月图片 | 三级小视频在线观看 | av久久久| 国产亚洲人成网站在线观看 | 97狠狠操 | 91在线看视频 | 黄色三级免费网址 | 天天射网站 | 久草视频中文在线 | 91亚洲精品国偷拍 | 91黄色影视 | 日本在线中文在线 | 深爱激情亚洲 | 亚洲欧洲成人精品av97 | 亚州国产视频 | 香蕉视频网址 | 国产精品手机看片 | 久草视频在线资源站 | 国产玖玖视频 | 亚洲视频久久久久 | 91欧美精品 | www.在线看片.com| 国产又粗又猛又黄又爽 | 国产精品无 | 人人爽人人看 | 久久九九精品 | 毛片一区二区 | 在线亚洲欧美视频 | 亚洲国产精品va在线 | 中国一级片在线播放 | 午夜婷婷网 | 日韩视频免费观看高清完整版在线 | 很黄很污的视频网站 | 视频精品一区二区三区 | 超碰在线成人 | 黄色特级一级片 | 高清av免费一区中文字幕 | 亚洲一级二级 | 在线观看 国产 | 91精品国产成人观看 | 日韩电影一区二区在线观看 | 99re8这里有精品热视频免费 | 日韩欧美网址 | 国产人成精品一区二区三 | 国产福利小视频在线 | 视频在线观看日韩 | 精品国产电影 | 久草香蕉在线视频 | 精品久久久久久国产 | 亚洲欧洲精品视频 | 黄色网在线免费观看 | 国产女人40精品一区毛片视频 | 日韩视频在线播放 | 激情综合网天天干 | 国产精品毛片一区视频 | 波多野结衣资源 | 日韩精品一区二区三区在线播放 | 97超碰资源 | 黄色免费看片网站 | 草免费视频 | 日日夜色| 欧美国产一区在线 | 96视频免费在线观看 | 五月婷在线 | 亚洲人成网站精品片在线观看 | 亚洲一区免费在线 | 中文字幕在线观看一区二区三区 | 国产亚洲精品久久久久久久久久久久 | 国产伦精品一区二区三区四区视频 | 在线中文日韩 | 国产精品96久久久久久吹潮 | 久久亚洲欧美 | www.亚洲精品视频 | 免费a级观看 | 久久精品亚洲一区二区三区观看模式 | 丁香激情五月婷婷 | 亚洲第一香蕉视频 | 国内视频| 97超碰影视 | 国产亚洲精品久久久久久久久久 | 成人av免费看 | 久久av一区二区三区亚洲 | 三级黄色大片在线观看 | 国产精品原创在线 | 在线观看av国产 | 美女免费电影 | 人人爱爱人人 | 手机成人av在线 | 色网站国产精品 | 中文av资源站 | 国产高h视频 | 四虎在线视频免费观看 | 97精品久久 | 亚洲九九爱 | 亚洲欧洲精品一区 | 99精品视频在线播放观看 | 国产成人精品999在线观看 | 日韩精品一区二区免费视频 | 亚洲一级电影在线观看 | 亚洲精品国产精品国自产观看浪潮 | 亚洲女人天堂成人av在线 | 久久毛片网 | 免费观看视频黄 | 激情在线网站 | 91大神精品视频在线观看 | 在线观看日韩精品视频 | av综合在线观看 | 欧美激情视频在线观看免费 | 天天射夜夜爽 | 麻花豆传媒mv在线观看网站 | 国产视频69 | 九九热在线免费观看 | 国产精品美女免费看 | 午夜精品av| 国产精品剧情在线亚洲 | 日韩精品一区二区在线观看视频 | 国产精品久久久久影视 | 啪啪小视频网站 | 亚洲人视频在线 | 国产亚洲精品美女 | 狠狠色丁香婷婷综合基地 | 98精品国产自产在线观看 | 亚洲va欧美va人人爽 | 久久亚洲人 | 日韩av电影中文字幕在线观看 | 黄色中文字幕在线 | 久久久久久国产精品999 | 成人免费在线视频 | 中文字幕在线第一页 | 精品 激情 | 亚洲精品久久久蜜桃 | 欧美日韩精品综合 | 久久精品久久久久久久 | 91成人免费观看视频 | 免费看黄视频 | 免费在线观看午夜视频 | 国产精品免费久久久久影院仙踪林 | 成人a v视频 | 亚洲精品456在线播放第一页 | 在线国产激情视频 | 日产中文字幕 | 天天综合导航 | 香蕉网站在线观看 | 久久久久久久久久久久国产精品 | 久久人人射 | 亚洲三级在线播放 | 国产精品24小时在线观看 | 一级一片免费观看 | 欧美激情视频一区二区三区 | 亚洲一区二区视频在线播放 | 激情综合亚洲 | 色婷婷狠狠18 | a级片久久 | 欧美极品裸体 | 天天搞天天| 国产91精品久久久久久 | 超级碰碰免费视频 | 亚洲精品美女视频 | 日本久久影视 | 911国产在线观看 | 国产一级在线免费观看 | 国产视频不卡一区 | 中文字幕电影高清在线观看 | 精品国产乱码久久久久久三级人 | 日韩免费播放 | 亚洲国产高清在线观看视频 | 在线看中文字幕 | 国产精品中文 | 一区二区三区日韩在线观看 | 96久久欧美麻豆网站 | 18性欧美xxxⅹ性满足 | 精品国产一区二区三区久久久久久 | 国产视频日韩 | 欧美精品首页 | 亚洲自拍偷拍色图 | 国产精品一区二区三区在线播放 | 天天操操操操操操 | 久久久国产精品成人免费 | 日韩国产精品一区 | 91麻豆精品国产 | 免费a视频在线 | 激情综合网五月激情 | 午夜精品电影 | 久久免费高清视频 | 天天干天天操天天搞 | 中文字幕电影网 | 91九色蝌蚪在线 | 亚州av网站大全 | 一本一道久久a久久精品 | av黄免费看| 精品一二三区 | 国产婷婷久久 | 久久精品精品电影网 | av在线电影免费观看 | 日日夜夜狠狠干 | 久久99免费视频 | 二区视频在线观看 | 精品特级毛片 | 欧美日韩p片 | 久久艹精品 | 精品国自产在线观看 | 成 人 黄 色 片 在线播放 | av黄色成人| 中文字幕影视 | 色九九影院| 国产精品小视频网站 | 亚洲自拍av在线 | 天天操天天弄 | 欧美一区免费在线观看 | 五月婷婷香蕉 | 日韩欧美在线视频一区二区三区 | 四虎国产永久在线精品 | 国产精品自产拍在线观看 | 人人干人人超 | 免费色黄 | 91桃色在线观看视频 | 午夜色场 | 日本成人中文字幕在线观看 | 日日干夜夜爱 | 狠狠色丁香久久婷婷综 | 在线免费观看不卡av | 日韩| 99tvdz@gmail.com| 天天操天天射天天添 | 9久久精品 | 婷婷激情欧美 | 久久久久久毛片 | 天天干天天搞天天射 | 日韩免| 日韩有码欧美 | 久久久久久久网站 | 国产69精品久久久久久 | 久久久久免费精品视频 | 成人性生交视频 | 精品国产一区二区三区四区在线观看 | 亚洲精品一区二区三区高潮 | 亚洲欧美在线综合 | a级一a一级在线观看 | 日韩精品视频一二三 | 成人在线免费小视频 | 欧美淫视频 | 碰超在线| 日韩免费一级a毛片在线播放一级 | 国产99久久久久久免费看 | 国产又粗又猛又爽又黄的视频免费 | 国产在线日本 | 欧美一区二区三区在线 | 久久国产精品一区二区 | 欧美在线观看视频免费 | 91精品久| 久久99深爱久久99精品 | 亚洲精品国产精品乱码在线观看 | 久久久性 | 国产日产精品久久久久快鸭 | 色婷婷综合久久久久 | 超碰日韩 | 中文字幕在线看视频 | 黄色一级大片在线观看 | 欧美99热| 久久精品视频观看 | 成人在线免费观看网站 | 免费在线播放黄色 | 极品久久久久久久 | 中文字幕乱码电影 | 91三级视频 | 国产日本在线观看 | 国产原创在线视频 | 在线免费av观看 | 成人午夜av电影 | 免费三及片| 99视频免费看 | 欧美日韩视频在线观看一区二区 | 日日日视频 | 91电影福利| 中文字幕一二三区 | 国产精品乱码久久 | 最近中文字幕完整视频高清1 | 国内精品久久久久久久影视麻豆 | 狠狠躁天天躁 | 在线看成人 | 99久久精品国产观看 | 在线va网站 | 国产成人精品久久亚洲高清不卡 | 久久国产剧场电影 | 成 人 黄 色视频免费播放 | 国产粉嫩在线 | 国产亚洲精品久久久久动 | av免费播放 | 免费观看黄 | avwww在线 | 2024国产精品视频 | 欧美一级久久久 | 亚洲国产精品久久久久婷婷884 | 狠狠色狠狠色综合系列 | 久久小视频 | 在线观看日韩一区 | av不卡中文 | 91在线观看欧美日韩 | 九九免费精品视频 | av黄色在线观看 | 亚洲综合在线发布 | 天天爽天天搞 | 精品一区二区免费视频 | 在线视频欧美精品 | 欧美日韩在线播放 | 国产精品一区二区三区99 | 91精品国产91 | 国产人成免费视频 | 日韩欧美综合 | 久久99精品视频 | www.五月婷 | 日韩激情一二三区 | 欧美色综合天天久久综合精品 | 久久午夜影视 | 精品国产片 | 免费一级特黄录像 | 国内精品小视频 | 国产精品久久久久av福利动漫 | 久久久久久国产一区二区三区 | 午夜美女视频 | 日本高清免费中文字幕 | 五月开心六月伊人色婷婷 | 欧美日韩免费观看一区=区三区 | 欧美a级在线 | www.com.黄| 国产精品中文字幕在线观看 | 视频99爱| 黄色app网站在线观看 | 中文字幕在线观看免费观看 | 亚洲精品动漫成人3d无尽在线 | 久久99亚洲精品久久久久 | 国产手机在线精品 | 激情久久小说 | 8x成人在线 | 99精品网站| 精品美女在线观看 | 一区二区三区在线免费观看视频 | 黄色一级在线观看 | 日韩在线视频线视频免费网站 | 六月天综合网 | 日韩专区 在线 | 在线视频福利 | 国产成人免费观看久久久 | 狠狠色丁香婷婷综合 | 天天干天天草天天爽 | 午夜精品福利影院 | 亚洲精品五月 | 亚洲一区二区91 | 国产精品一区二区三区电影 | 国产男女爽爽爽免费视频 | 色小说在线 | 在线韩国电影免费观影完整版 | 人人干天天射 | 亚洲激情国产精品 | 亚洲欧美色婷婷 | 亚洲电影免费 | 亚洲欧洲成人精品av97 | 国产精品小视频网站 | av高清免费 | 欧美日韩在线播放一区 | 国产毛片久久久 | 中文字幕二区三区 | 国产中文字幕一区 | 91九色在线观看 | 九九涩涩av台湾日本热热 | 最近中文字幕在线播放 | 久久精品日产第一区二区三区乱码 | 肉色欧美久久久久久久免费看 | 在线成人免费电影 | 日韩成人不卡 | 日韩av一区二区在线播放 | 91精品国产自产在线观看永久 | 丁香婷婷社区 | 中文字幕在线专区 | 精品国产欧美一区二区 | 日韩精品第一区 | 天天色天天草天天射 | 草久中文字幕 | 中文字幕一区二区三区四区视频 | 国产性天天综合网 | 国产专区日韩专区 | 久久久久中文字幕 | 久久成人国产精品入口 | 久草视频99 | 日韩一区精品 | 国产成人精品一区二区三区福利 | 丰满少妇在线观看网站 | 日韩高清三区 | 中文字幕在线播放一区二区 | 婷婷丁香色 | 国产欧美日韩一区 | 91精品1区 | 免费a级毛片在线看 | 国产精品福利在线观看 | 久久久午夜精品理论片中文字幕 | 探花视频在线版播放免费观看 | 天天摸日日摸人人看 | 日韩精品免费一区二区在线观看 | 日韩欧美在线视频一区二区三区 | 亚洲精品在线观看不卡 | 天天色天天操综合 | 国产精品毛片一区二区 | 亚洲伦理一区二区 | 99久久er热在这里只有精品15 | 啪啪小视频网站 | 91黄站| 黄色特级片 | 欧美电影黄色 | 五月婷婷欧美视频 | 中文字幕一区二区三区四区在线视频 | 亚洲一区日韩精品 | 99久久99精品 | 国产精品毛片网 | 九九久久久久99精品 | 在线电影日韩 | 91一区二区在线 | 男女拍拍免费视频 | 成人av片在线观看 | 99精品观看| 日日综合网 | 国产美女无遮挡永久免费 | 天天干天天做 | 色综合久久久久久久 | 久久99国产精品二区护士 | 午夜三级影院 | 五月婷婷激情网 | 欧美激情另类 | 日韩电影久久久 | 视频在线一区 | 人人干人人草 | 日韩网站视频 | av高清一区二区三区 | 中文字幕在线观看第一区 | 久久国产美女视频 | 日本中文字幕系列 | av超碰免费在线 | 国产亚洲情侣一区二区无 | 免费网站v | 久久公开免费视频 | 天天操天天舔天天爽 | 国产精品一区二区久久精品爱涩 | 天天色天天干天天 | 欧美日韩国产欧美 | 手机看片福利 | 在线播放一区二区三区 | 国产1区2 | 美女黄网站视频免费 | 337p西西人体大胆瓣开下部 | 天天综合天天综合 | 在线观看网站av | 色多多污污 | 久久久av电影 | 日日夜夜网 | 欧美午夜久久 | 中文字幕一区二区三区四区 | 中文字幕欧美日韩va免费视频 | 亚洲a成人v | 欧美坐爱视频 | 国模视频一区二区三区 | 成人黄色毛片视频 | 天天天天天天天操 | 天海冀一区二区三区 | 伊人色**天天综合婷婷 | 亚洲国产无 | 超碰国产97 | 国产成人免费观看 | 91看片淫黄大片在线播放 | 成人亚洲综合 | 亚洲欧美视频在线观看 | 久久久久在线观看 | 人人玩人人添人人澡超碰 | a久久久久 | 久久亚洲国产精品 | 日本中文字幕在线观看 | 人人插人人搞 | 超碰97中文| av网站在线观看播放 | 韩日三级av| 成人在线观看你懂的 | 欧美日韩一区三区 | 激情综合五月婷婷 | 国产综合91| 久久国产精品99久久久久久进口 | 国内视频在线 | 日韩中字在线 | 三级在线国产 | 成人免费共享视频 | 在线免费观看亚洲视频 | 狠狠干干 | 香蕉网站在线观看 | 久久国产精品久久久 | 天堂av最新网址 | 日本免费久久高清视频 | free. 性欧美.com | 国产一级免费观看视频 | 日产乱码一二三区别免费 | 亚洲小视频在线观看 | 久草热视频 | 日韩视| 天天综合网 天天 | 99欧美| 最新一区二区三区 | 天天操天天干天天玩 | 亚洲最大在线视频 | 九九在线免费视频 | 97在线视频免费观看 | 亚洲免费国产视频 | 日本中文字幕在线一区 | 亚洲男模gay裸体gay | 美女啪啪图片 | 久久爱资源网 | 国产精品18久久久 | 国产成人精品一区二区三区福利 | 亚洲国产欧美在线看片xxoo | 久久99久久99精品免费看小说 | 欧美日韩视频 | 久草a视频| 2017狠狠干| 国产成人精品亚洲 | 手机av在线免费观看 | 伊人影院av | 中文字幕一区二区三区乱码不卡 | 四川妇女搡bbbb搡bbbb搡 | 在线视频 一区二区 | 在线观看中文字幕一区 | 国产成人精品一区一区一区 | 国产女人40精品一区毛片视频 | 婷婷中文字幕 | 久精品一区 | 99精品视频播放 | 久久久久久久亚洲精品 | 欧美吞精 | 97香蕉久久超级碰碰高清版 | 欧美日韩视频精品 | 波多野结衣理论片 | 国产亚洲观看 | 国产99久久久国产精品成人免费 | 欧美成人中文字幕 | 黄色一级在线视频 | 国产免费久久久久 | 国产精品黄色影片导航在线观看 | 三级大片网站 | 国产亚洲婷婷免费 | 久久精品这里都是精品 | .精品久久久麻豆国产精品 亚洲va欧美 | 99热日本 | 久久这里精品视频 | 亚洲一区网| 精品视频资源站 | 美女精品在线 | 久久免费播放 | av福利资源| 2019久久精品 | 国产美女免费观看 | 免费日韩在线 | 97国产一区二区 | 五月婷婷综合网 | 免费黄在线观看 | av手机版 | 日韩激情免费视频 | 欧美精品你懂的 | 久久爽久久爽久久av东京爽 | 国产精品毛片一区二区在线看 | 综合av在线 | www.五月婷| 成人在线观看你懂的 | 国产精品一区二区无线 | 九热精品| 色婷婷视频网 | 国产剧情久久 | 欧美极品少妇xbxb性爽爽视频 | 手机在线看a | 亚洲国产视频在线 | 日韩性久久 | 中文字幕免费不卡视频 | 91免费在线看片 | 91新人在线观看 | 日韩一级成人av | 国产原创av片 | 国产一级电影免费观看 | 天天操天天干天天操天天干 | 国产69精品久久久久久久久久 | 狠狠色噜噜狠狠狠狠2021天天 | 亚洲精品毛片一级91精品 | 国产精品专区在线观看 | 国产精品网站一区二区三区 | 亚洲免费精品视频 | 美女性爽视频国产免费app | av在线成人 | 久草资源在线 | 91日韩在线视频 | 日韩二区在线观看 | 国产精品一区二区在线播放 | 婷婷深爱五月 | 日操操 | 尤物一区二区三区 | 亚洲精品在线播放视频 | 久久精品区 | 午夜黄色一级片 | 国产精品专区在线观看 | 伊人伊成久久人综合网小说 | 精一区二区 | 婷婷六月综合网 | 国产美女久久久 | 最新三级在线 | 国产九色视频在线观看 | 久久草视频 | 久久精品牌麻豆国产大山 | 国产又黄又猛又粗 | 色小说在线 | 999久久 | av网站在线免费观看 | 免费高清国产 | 99精品视频在线观看免费 | 日本大片免费观看在线 | 日韩啪视频| 日韩在线观看一区二区 | 88av色| 中文字幕免费高清 | 日本中文字幕在线观看 | 国产资源在线观看 | 亚洲精品视频网站在线观看 | 99久高清在线观看视频99精品热在线观看视频 | 超碰在线观看av.com | 免费在线观看成人av | 国产精品一区二区久久精品爱涩 | 久久成人一区二区 | 亚洲免费精品一区二区 | 99国产情侣在线播放 | 亚州激情视频 | 国产免费久久av | 91片黄在线观看 | 91精品国产欧美一区二区 | 久久久久北条麻妃免费看 | 中文字幕二区三区 | 色婷婷综合成人av | 337p日本欧洲亚洲大胆裸体艺术 | 国产精品久久精品国产 | 日日夜夜人人精品 | 日韩一区二区三区高清免费看看 | 91av视频免费在线观看 | 91热精品| 91高清视频免费 | 91手机视频 | 插久久| 97在线视频免费播放 | 最新国产在线 | 久草在线视频首页 | 欧美一区二区三区在线视频观看 | 99久久久久国产精品免费 | 亚洲精品在线一区二区三区 | 4438全国亚洲精品观看视频 | 麻豆国产精品一区二区三区 | 久久成人国产精品 | 色婷婷激情综合 | 九九在线高清精品视频 | 天天射天天搞 | 91免费在线视频 | 久久久国产精品免费 | 免费成人结看片 | 麻豆传媒一区二区 | 国产资源在线视频 | 激情婷婷 | 日韩成人精品一区二区三区 | 亚洲综合色播 | 91av99| 91在线免费播放 | 丁香六月伊人 | 伊人天堂av | 成在线播放 | 久精品视频免费观看2 | 国产精品免费不 | 69视频在线播放 | 国产一级片在线播放 | 亚洲精品国产免费 | 精品久久一二三区 | 日韩专区av| 国内视频一区二区 | 免费在线a | 国产片免费在线观看视频 | 精品一二三四五区 | 在线国产不卡 | 日韩69视频 | 在线中文视频 | 干干日日 | 久久在线看 | 久久亚洲综合国产精品99麻豆的功能介绍 | 成人日批视频 | 超碰在线公开免费 | 国产69精品久久久久久 | 91麻豆精品久久久久久 | 国产精品一区二区62 | 91av蜜桃| 国产精品美女视频网站 | 99精品在线视频观看 | 色婷婷播放| 久久免费试看 | 日韩av影视在线 | 日韩女同一区二区三区在线观看 | 天天色中文 | 国产专区欧美专区 | 欧美精选一区二区三区 |