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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

javascript 编程思想

發布時間:2025/1/21 javascript 61 豆豆
生活随笔 收集整理的這篇文章主要介紹了 javascript 编程思想 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

為什么80%的碼農都做不了架構師?>>> ??

?JavaScript中的數據很簡潔的。簡單數據只有 undefined, null, boolean, number和string這五種,而復雜數據只有一種,即object。
JavaScript中的代碼只體現為一種形式,就是function。

?注意:以上單詞都是小寫的,不要和Number, String, Object, Function等JavaScript內置函數混淆了。要知道,JavaScript語言是區分大小寫的呀!

任何一個JavaScript的標識、常量、變量和參數都只是unfined, null, bool, number, string, object 和 function類型中的一種,也就typeof返回值表明的類型。除此之外沒有其他類型了。

簡單數據類型:

undefined:?? 代表一切未知的事物,啥都沒有,無法想象,代碼也就更無法去處理了。
?? ? ? ? ? ? ? ? ? ?注意:typeof(undefined) 返回也是 undefined。
?? ? ? ? ? ? ? ? ? ?可以將undefined賦值給任何變量或屬性,但并不意味了清除了該變量,反而會因此多了一個屬性。

null: ? ? ? ? ? ? 有那么一個概念,但沒有東西。無中似有,有中還無。
?? ? ? ? ? ? ? ? ? ?注意:typeof(null)返回object,但null并非object,具有null值的變量也并非object。

boolean:????? 是就是,非就非,對就對,錯就錯,絕對明確。既能被代碼處理,也可以控制代碼的流程。

number: ? ? ? 線性的事物,大小和次序分明,多而不亂。便于代碼進行批量處理,也控制代碼的迭代和循環等。
?? ? ? ? ? ? ? ? ? ?注意:typeof(NaN)和typeof(Infinity)都返回number 。
?? ? ? ? ? ? ? ? ? ? ? ? ? ? ?NaN參與任何數值計算的結構都是NaN,而且 NaN != NaN 。
????????????????????????????? Infinity / Infinity = NaN 。

string:???????? 面向人類的理性事物,而不是機器信號。人機信息溝通,代碼據此理解人的意圖等等,都靠它了。

簡單類型都不是對象,JavaScript沒有將對象化的能力賦予這些簡單類型。直接被賦予簡單類型常量值的標識符、變量和參數都不是一個對象。

所謂“對象化”,就是可以將數據和代碼組織成復雜結構的能力。JavaScript中只有object類型和function類型提供了對象化的能力。

沒有類
object就是對象的類型。在JavaScript中不管多么復雜的數據和代碼,都可以組織成object形式的對象。
但JavaScript卻沒有 “類”的概念!
這樣,我們先來看一段JavaScript程序:
???? var ?life? = ?{};
????
for (life.age? = ? 1 ;?life.age? <= ? 3 ;?life.age ++ )
????{
????????
switch (life.age)
????????{
????????????
case ? 1 :?life.body? = ? " 卵細胞 " ;
????????????????????life.say?
= ? function (){alert( this .age + this .body)};
????????????????????
break ;
????????????
case ? 2 :?life.tail? = ? " 尾巴 " ;
????????????????????life.gill?
= ? " " ;
????????????????????life.body?
= ? " 蝌蚪 " ;
????????????????????life.say?
= ? function (){alert( this .age + this .body + " - " + this .tail + " , " + this .gill)};
????????????????????
break ;
????????????
case ? 3 :? delete ?life.tail;
????????????????????
delete ?life.gill;
????????????????????life.legs?
= ? " 四條腿 " ;
????????????????????life.lung?
= ? " " ;
????????????????????life.body?
= ? " 青蛙 " ;
????????????????????life.say?
= ? function (){alert( this .age + this .body + " - " + this .legs + " , " + this .lung)};
????????????????????
break ;
????????};
????????life.say();
????};

這段JavaScript程序一開始產生了一個生命對象life,life誕生時只是一個光溜溜的對象,沒有任何屬性和方法。在第一次生命過程中,它有了 一個身體屬性body,并有了一個say方法,看起來是一個“卵細胞”。在第二次生命過程中,它又長出了“尾巴”和“腮”,有了tail和gill屬性, 顯然它是一個“蝌蚪”。在第三次生命過程中,它的tail和gill屬性消失了,但又長出了“四條腿”和“肺”,有了legs和lung屬性,從而最終變 成了“青蛙”。不過,在看完這段程序之后,請你思考一個問題:

我們一定需要類嗎?

還記得兒時那個“小蝌蚪找媽媽”的童話嗎?可愛的小蝌蚪也就是在其自身類型不斷演化過程 中,逐漸變成了和媽媽一樣的“類”,從而找到了自己的媽媽。這個童話故事中蘊含的編程哲理就是:對象的“類”是從無到有,又不斷演化,最終又消失于無形之 中的...

所以,JavaScript中沒有“類”,類已化于無形,與對象融為一體。正是由于放下了“類”這個概念,JavaScript的對象才有了其他編程語言所沒有的活力。

函數的魔力 接下來,我們再討論一下JavaScript函數的魔力吧。

JavaScript的代碼就只有function一種形式,function就是函數的類型。也許其他編程語言還有procedure或 method等代碼概念,但在JavaScript里只有function一種形式。當我們寫下一個函數的時候,只不過是建立了一個function類型 的實體而已。請看下面的程序:
???? function ?myfunc()
????{
????????alert(
" hello " );
????};
????
????alert(
typeof (myfunc));
這個代碼運行之后可以看到typeof(myfunc)返回的是function。以上的函數寫法我們稱之為“定義式”的,如果我們將其改寫成下面的“變量式”的,就更容易理解了:
???? var ?myfunc? = ? function ?()
????????{
????????????alert(
" hello " );
????????};
????
????alert(
typeof (myfunc));
這里明確定義了一個變量myfunc,它的初始值被賦予了一個function的實體。因此,typeof(myfunc)返回的也是function。 其實,這兩種函數的寫法是等價的,除了一點細微差別,其內部實現完全相同。也就是說,我們寫的這些JavaScript函數只是一個命了名的變量而已,其 變量類型即為function,變量的值就是我們編寫的函數代碼體。

問題:既然函數只是變量,那么變量就可以被隨意賦值并用到任意地方啰?

我們來看看下面的代碼:
???? var ?myfunc? = ? function ?()
????????{
????????????alert(
" hello " );
????????};
????myfunc();?
// 第一次調用myfunc,輸出hello
????
????myfunc?
= ? function ?()
????????{
????????????alert(
" yeah " );
????????};????
????myfunc();?
// 第二次調用myfunc,將輸出yeah
好了,我們又來把上面的代碼改成第一種定義式的函數形式:
???? function ?myfunc?()
????{
????????alert(
" hello " );
????};
????myfunc();?
// 這里調用myfunc,輸出yeah而不是hello
????
????
function ?myfunc?()
????{
????????alert(
" yeah " );
????};????
????myfunc();?
// 這里調用myfunc,當然輸出yeah
這又是為什么呢?

原來,JavaScript執行引擎并非一行一行地分析和執行程序,而是一段一段地分析執行。而且,在同一段程序的分析執行中,定義式的函數語句會被提 取出來優先執行函數定義執行完之后,才會按順序執行其他語句代碼。也就是說,在第一次調用myfunc之前,第一個函數語句定義的代碼邏輯,已被第二個 函數定義語句覆蓋了。所以,兩次都調用都是執行最后一個函數邏輯了。

如果把這個JavaScript代碼分成兩段,例如將它們寫在一個html中,并用<script/>標簽將其分成這樣的兩塊:
< script >
????
function ?myfunc?()
????{
????????alert(
" hello " );
????};
????myfunc();?
// 這里調用myfunc,輸出hello
</ script >

< script >
????
function ?myfunc?()
????{
????????alert(
" yeah " );
????};????
????myfunc();?
// 這里調用myfunc,輸出yeah
</ script > 這時,輸出才是各自按順序來的,也證明了JavaScript的確是一段段地執行的

一段代碼中的定義式函數語句會優先執行,這似乎有點象靜態語言的編譯概念。所以,這一特征也被有些人稱為:JavaScript的“預編譯”

大多數情況下,我們也沒有必要去糾纏這些細節問題。只要你記住一點:JavaScript里的代碼也是一種數據,同樣可以被任意賦值和修改的,而它的值就是代碼的邏輯。只是,與一般數據不同的是,函數是可以被調用執行的。

然而, JavaScript函數的神奇之處還體現在另外兩個方面:一是函數function類型本身也具有對象化的能力,二是函數function與對象 object超然的結合能力。

奇妙的對象
先來說說函數的對象化能力。

任何一個函數都可以為其動態地添加或去除屬性,這些屬性可以是簡單類型,可以是對象,也可以是其他函數。也就是說,函數具有對象的全部特征,你完全可以把 函數當對象來用。其實,函數就是對象,只不過比一般的對象多了一個括號“()”操作符,這個操作符用來執行函數的邏輯。即,函數本身還可以被調用,一般對 象卻不可以被調用,除此之外完全相同。請看下面的代碼:
???? function ?Sing()
????{
????????
with (arguments.callee)
??????????alert(author?
+ ? " " ? + ?poem);
????};
????Sing.author?
= ? " 李白 " ;
????Sing.poem?
= ? " 漢家秦地月,流影照明妃。一上玉關道,天涯去不歸 " ;
????Sing();
????Sing.author?
= ? " 李戰 " ;
????Sing.poem?
= ? " 日出漢家天,月落陰山前。女兒琵琶怨,已唱三千年 " ;
????Sing();
在這段代碼中,Sing函數被定義后,又給Sing函數動態地增加了author和poem屬性。將author和poem屬性設為不同的作者和詩句,在 調用Sing()時就能顯示出不同的結果。這個示例用一種詩情畫意的方式,讓我們理解了JavaScript函數就是對象的本質,也感受到了 JavaScript語言的優美。

好了,以上的講述,我們應該算理解了function類型的東西都是和object類型一樣的東西,這種東西被我們稱為“對象”。我們的確可以這樣去看待這些“對象”,因為它們既有“屬性”也有“方法”嘛。但下面的代碼又會讓我們產生新的疑惑:
???? var ?anObject? = ?{};?? // 一個對象
????anObject.aProperty? = ? " Property?of?object " ;?? // 對象的一個屬性
????anObject.aMethod? = ? function (){alert( " Method?of?object " )};? // 對象的一個方法
???? // 主要看下面:
????alert(anObject[ " aProperty " ]);??? // 可以將對象當數組以屬性名作為下標來訪問屬性
????anObject[ " aMethod " ]();?????????? // 可以將對象當數組以方法名作為下標來調用方法
???? for (? var ?s? in ?anObject)??????????? // 遍歷對象的所有屬性和方法進行迭代化處理
????????alert(s? + ? " ?is?a? " ? + ? typeof (anObject[s]));
同樣對于function類型的對象也是一樣:
???? var ?aFunction? = ?function() {};?? // 一個函數
????aFunction.aProperty? = ? " Property?of?function " ;?? // 函數的一個屬性
????aFunction.aMethod? = ? function (){alert( " Method?of?function " )};? // 函數的一個方法
???? // 主要看下面:
????alert(aFunction[ " aProperty " ]);??? // 可以將函數當數組以屬性名作為下標來訪問屬性
????aFunction[ " aMethod " ]();?????????? // 可以將函數當數組以方法名作為下標來調用方法
???? for (? var ?s? in ?aFunction)??????????? // 遍歷函數的所有屬性和方法進行迭代化處理
????????alert(s? + ? " ?is?a? " ? + ? typeof (aFunction[s])); 是的,對象和函數可以象數組一樣,用屬性名或方法名作為下標來訪問并處理。那么,它到底應該算是數組呢,還是算對象?

我們知道,數組應該算是線性數據結構,線性數據結構一般有一定的規律,適合進行統一的批量迭代操作等,有點像波。而對象是離散數據結構,適合描述分散的和個性化的東西,有點像粒子。因此,我們也可以這樣問:JavaScript里的對象到底是波還是粒子?

如果存在對象量子論,那么答案一定是:波粒二象性!
因此,JavaScript里的函數和對象既有對象的特征也有數組的特征。這里的數組被稱為“字典”,一種可以任意伸縮的名稱值對兒的集合。其實, object和function的內部實現就是一個字典結構,但這種字典結構卻通過嚴謹而精巧的語法表現出了豐富的外觀。你也可以在需要的時候,自由選擇用對象還是數組來解釋和處理問題。只要善于把握 JavaScript的這些奇妙特性,就可以編寫出很多簡潔而強大的代碼來。

放下對象
我們再來看看function與object的超然結合吧。
JavaScript中也有this,但這個this卻與C++、C#或Java等語言的this不同。一般編程語言的this就是對象自己,而 JavaScript的this卻并不一定!this可能是我,也可能是你,可能是他,反正是我中有你,你中有我。

?我們來看下面的代碼:
???? function ?WhoAmI()??????? // 定義一個函數WhoAmI
????{
????????alert(
" I'm? " ? + ? this .name? + ? " ?of? " ? + ? typeof ( this ));
????};
????
????WhoAmI();???
// 此時是this當前這段代碼的全局對象,在瀏覽器中就是window對象,其name屬性為空字符串。輸出:I'm?of?object

????
var ?BillGates? = ?{name:? " Bill?Gates " };
????BillGates.WhoAmI?
= ?WhoAmI;?? // 將函數WhoAmI作為BillGates的方法。
????BillGates.WhoAmI();????????? // 此時的this是BillGates。輸出:I'm?Bill?Gates?of?object
????
????
var ?SteveJobs? = ?{name:? " Steve?Jobs " };
????SteveJobs.WhoAmI?
= ?WhoAmI;?? // 將函數WhoAmI作為SteveJobs的方法。
????SteveJobs.WhoAmI();????????? // 此時的this是SteveJobs。輸出:I'm?Steve?Jobs?of?object

????WhoAmI.call(BillGates);?????
// 直接將BillGates作為this,調用WhoAmI。輸出:I'm?Bill?Gates?of?object
????WhoAmI.call(SteveJobs);????? // 直接將SteveJobs作為this,調用WhoAmI。輸出:I'm?Steve?Jobs?of?object
????
????BillGates.WhoAmI.call(SteveJobs);???
// 將SteveJobs作為this,卻調用BillGates的WhoAmI方法。輸出:I'm?Steve?Jobs?of?object
????SteveJobs.WhoAmI.call(BillGates);??? // 將BillGates作為this,卻調用SteveJobs的WhoAmI方法。輸出:I'm?Bill?Gates?of?object

????WhoAmI.WhoAmI?
= ?WhoAmI;????? // 將WhoAmI函數設置為自身的方法。
????WhoAmI.name? = ? " WhoAmI " ;
????WhoAmI.WhoAmI();????????????
// 此時的this是WhoAmI函數自己。輸出:I'm?WhoAmI?of?function
????????
????({name:?
" nobody " ,?WhoAmI:?WhoAmI}).WhoAmI();???? // 臨時創建一個匿名對象并設置屬性后調用WhoAmI方法。輸出:I'm?nobody?of?object 從上面的代碼可以看出,同一個函數可以從不同的角度來調用,this并不一定是函數本身所屬的對象。this只是在任意對象和function元素結合時的一個概念,是種結合比起一般對象語言的默認結合更加靈活,顯得更加超然和灑脫。

在JavaScript函數中,你只能把this看成當前要服務的“這個”對象。this是一個特殊的內置參數,根據this參數,您可以訪問到“這個” 對象的屬性和方法,但卻不能給this參數賦值。在一般對象語言中,方法體代碼中的this可以省略的,成員默認都首先是“自己”的。但 JavaScript卻不同,由于不存在“自我”,當訪問“這個”對象時,this不可省略!

JavaScript提供了傳遞this參數的多種形式和手段,其中,象BillGates.WhoAmI()和SteveJobs.WhoAmI()這 種形式,是傳遞this參數最正規的形式,此時的this就是函數所屬的對象本身。而大多數情況下,我們也幾乎很少去采用那些借花仙佛的調用形式。

對象素描
怎樣建立對象?

在前面的示例中,我們已經涉及到了對象的建立了。我們使用了一種被稱為JavaScript Object Notation(縮寫JSON)的形式,翻譯為中文就是“JavaScript對象表示法”。

JSON為創建對象提供了非常簡單的方法。例如,創建一個沒有任何屬性的對象:
var ?o? = ?{};
創建一個對象并設置屬性及初始值:
var ?person? = ?{name:? " Angel " ,?age:? 18 ,?married:? false };
創建一個對象并設置屬性和方法:
var ?speaker? = ?{text:? " Hello?World " ,?say:? function (){alert( this .text)}};
創建一個更復雜的對象,嵌套其他對象和對象數組等:
???? var ?company? =
????{
????????name:?
" Microsoft " ,
????????product:?
" softwares " ,
????????chairman:?{name:?
" Bill?Gates " ,?age:? 53 ,?Married:? true },
????????employees:?[{name:?
" Angel " ,?age:? 26 ,?Married:? false },?{name:? " Hanson " ,?age:? 32 ,?Marred:? true }],
????????readme:?
function ()?{document.write( this .name? + ? " ?product? " ? + ? this .product);}
????};

JSON的形式就是用大括“{}”號包括起來的項目列表,每一個項目間并用逗號“,”分隔,而項目就是用冒號“:”分隔的屬性名和屬性值。這是典型的字典 表示形式,也再次表明了 JavaScript里的對象就是字典結構。不管多么復雜的對象,都可以被一句JSON代碼來創建并賦值。

其實,JSON就是JavaScript對象最好的序列化形式,它比XML更簡潔也更省空間。對象可以作為一個JSON形式的字符串,在網絡間自 由傳遞和交換信息。而當需要將這個JSON字符串變成一個JavaScript對象時,只需要使用eval函數這個強大的數碼轉換引擎,就立即能得到一個 JavaScript內存對象。正是由于JSON的這種簡單樸素的天生麗質,才使得她在AJAX舞臺上成為璀璨奪目的明星。

構造對象 好了,接下我們來討論一下對象的另一種創建方法。

除JSON外,在JavaScript中我們可以使用new操作符結合一個函數的形式來創建對象。例如:
???? function ?MyFunc()?{};????????? // 定義一個空函數
???? var ?anObj? = ? new ?MyFunc();?? // 使用new操作符,借助MyFun函數,就創建了一個對象
JavaScript的這種創建對象的方式可真有意思,如何去理解這種寫法呢?
? 其實,可以把上面的代碼改寫成這種等價形式:
???? function ?MyFunc(){};
????
var ?anObj? = ?{};????? // 創建一個對象
????MyFunc.call(anObj);? // 將anObj對象作為this指針調用MyFunc函數
我們就可以這樣理解,JavaScript先用new操作符創建了一個對象,緊接著就將這個對象作為this參數調用了后面的函數。其實, JavaScript內部就是這么做的,而且任何函數都可以被這樣調用!但從 “anObj = new MyFunc()” 這種形式,我們又看到一個熟悉的身影,C++和C#不就是這樣創建對象的嗎?原來,條條大路通靈山,殊途同歸啊!

君看到此處也許會想,我們為什么不可以把這個MyFunc當作構造函數呢?恭喜你,答對了!JavaScript也是這么想的!請看下面的代碼:?
?1 ? ???? function ?Person(name)??? // 帶參數的構造函數
?2 ? ????{
?3 ? ???????? this .name? = ?name;??? // 將參數值賦給給this對象的屬性
?4 ? ???????? this .SayHello? = ? function ()?{alert( " Hello,?I'm? " ? + ? this .name);};??? // 給this對象定義一個SayHello方法。
?5 ? ????};
?6 ?
?7 ? ???? function ?Employee(name,?salary)????? // 子構造函數
?8 ? ????{
?9 ? ????????Person.call( this ,?name);???????? // 將this傳給父構造函數
10 ? ???????? this .salary? = ?salary;??????? // 設置一個this的salary屬性
11 ? ???????? this .ShowMeTheMoney? = ? function ()?{alert( this .name? + ? " ?$ " ? + ? this .salary);};?? // 添加ShowMeTheMoney方法。
12 ? ????};
13 ? ????
14 ? ???? var ?BillGates? = ? new ?Person( " Bill?Gates " );??? // 用Person構造函數創建BillGates對象
15 ? ???? var ?SteveJobs? = ? new ?Employee( " Steve?Jobs " ,? 1234 );??? // 用Empolyee構造函數創建SteveJobs對象
16 ?
17 ? ????BillGates.SayHello();??? // 顯示:I'm?Bill?Gates
18 ? ????SteveJobs.SayHello();??? // 顯示:I'm?Steve?Jobs
19 ? ????SteveJobs.ShowMeTheMoney();??? // 顯示:Steve?Jobs?$1234
20 ?
21 ? ????alert(BillGates.constructor? == ?Person);?? // 顯示:true
22 ? ????alert(SteveJobs.constructor? == ?Employee);?? // 顯示:true
23 ? ????
24 ? ????alert(BillGates.SayHello? == ?SteveJobs.SayHello);? // 顯示:false 這段代碼表明,函數不但可以當作構造函數,而且還可以帶參數還可以為對象添加成員和方法。其中的第9行,Employee構造函數又將自己接收的 this作為參數調用Person構造函數,這就是相當于調用基類的構造函數。第21、22行還表明這樣一個意思:BillGates是由Person構 造的,而SteveJobs是由Employee構造的。對象內置的constructor屬性還指明了構造對象所用的具體函數!

其實,如果你愿意把函數當作“類”的話,她就是“類”,因為她本來就有“類”的那些特征。難道不是嗎?她生出的兒子各個都有相同的特征,而且構造函數也與類同名嘛!

但要注意的是,用構造函數操作this對象創建出來的每一個對象,不但具有各自的成員數據,而且還具有各自的方法數據。換句話說,方法的代碼體(體現函數 邏輯的數據)在每一個對象中都存在一個副本。盡管每一個代碼副本的邏輯是相同的,但對象們確實是各自保存了一份代碼體。上例中的最后一句說明了這一實事, 這也解釋了JavaScript中的函數就是對象的概念。

同一類的對象各自有一份方法代碼顯然是一種浪費。在傳統的對象語言中,方法函數并不象JavaScript那樣是個對象概念。即使也有函數指針、方法指針或委托那樣的變化形式,但其實質也是對同一份代碼的引用。一般的對象語言很難遇到這種情況。

不過,JavaScript語言有大的靈活性。我們可以先定義一份唯一的方法函數體,并在構造this對象時使用這唯一的函數對象作為其方法,就能共享方法邏輯。例如:
???? function ?SayHello()????? // 先定義一份SayHello函數代碼
????{
????????alert(
" Hello,?I'm? " ? + ? this .name);
????};
????
????
function ?Person(name)??? // 帶參數的構造函數
????{
????????
this .name? = ?name;??? // 將參數值賦給給this對象的屬性
???????? this .SayHello? = ?SayHello;??? // 給this對象SayHello方法賦值為前面那份SayHello代碼。
????};

????
var ?BillGates? = ? new ?Person( " Bill?Gates " );??? // 創建BillGates對象
???? var ?SteveJobs? = ? new ?Person( " Steve?Jobs " );??? // 創建SteveJobs對象
????
????alert(BillGates.SayHello?
== ?SteveJobs.SayHello);? // 顯示:true 其中,最后一行的輸出結果表明兩個對象確實共享了一個函數對象。雖然,這段程序達到了共享了一份方法代碼的目的,但卻不怎么優雅。因為,定義 SayHello方法時反映不出其與Person類的關系。“優雅”這個詞用來形容代碼,也不知道是誰先提出來的。不過,這個詞反映了程序員已經從追求代 碼的正確、高效、可靠和易讀等基礎上,向著追求代碼的美觀感覺和藝術境界的層次發展,程序人生又多了些浪漫色彩。

顯然,JavaScript早想到了這一問題,她的設計者們為此提供了一個有趣的prototype概念

初看原型
prototype源自法語,軟件界的標準翻譯為“原型”,代表事物的初始形態也含有模型和樣板的意義。JavaScript中的prototype概念恰如其分地反映了這個詞的內含,我們不能將其理解為C++的prototype那種預先聲明的概念。

JavaScript的所有function類型的對象都有一個prototype屬性這個prototype屬性本身又是一個object類型的對 象,因此我們也可以給這個prototype對象添加任意的屬性和方法。既然prototype是對象的“原型”,那么由該函數構造出來的對象應該都會具 有這個“原型”的特性。事實上,在構造函數的prototype上定義的所有屬性和方法,都是可以通過其構造的對象直接訪問和調用的。也可以這么說, prototype提供了一群同類對象共享屬性和方法的機制。

我們先來看看下面的代碼:
???? function ?Person(name)
????{
????????
this .name? = ?name;??? // 設置對象屬性,每個對象各自一份屬性數據
????};
????
????Person.prototype.SayHello?
= ? function ()?? // 給Person函數的prototype添加SayHello方法。
????{
????????alert(
" Hello,?I'm? " ? + ? this .name);
????}

????
var ?BillGates? = ? new ?Person( " Bill?Gates " );??? // 創建BillGates對象
???? var ?SteveJobs? = ? new ?Person( " Steve?Jobs " );??? // 創建SteveJobs對象

????BillGates.SayHello();???
// 通過BillGates對象直接調用到SayHello方法
????SteveJobs.SayHello();??? // 通過SteveJobs對象直接調用到SayHello方法

????alert(BillGates.SayHello?
== ?SteveJobs.SayHello);? // 因為兩個對象是共享prototype的SayHello,所以顯示:true 程序運行的結果表明,構造函數的prototype上定義的方法確實可以通過對象直接調用到,而且代碼是共享的。顯然,把方法設置到prototype的 寫法顯得優雅多了,盡管調用形式沒有變,但邏輯上卻體現了方法與類的關系,相對前面的寫法,更容易理解和組織代碼

那么,對于多層次類型的構造函數情況又如何呢?

我們再來看下面的代碼:
?1 ? ???? function ?Person(name)??? // 基類構造函數
?2 ? ????{
?3 ? ???????? this .name? = ?name;
?4 ? ????};
?5 ? ????
?6 ? ????Person.prototype.SayHello? = ? function ()?? // 給基類構造函數的prototype添加方法
?7 ? ????{
?8 ? ????????alert( " Hello,?I'm? " ? + ? this .name);
?9 ? ????};
10 ? ????
11 ? ???? function ?Employee(name,?salary)? // 子類構造函數
12 ? ????{
13 ? ????????Person.call( this ,?name);???? // 調用基類構造函數
14 ? ???????? this .salary? = ?salary;
15 ? ????};
16 ? ????
17 ? ????Employee.prototype? = ? new ?Person();?? // 建一個基類的對象作為子類原型的原型,這里很有意思
18 ? ????
19 ? ????Employee.prototype.ShowMeTheMoney? = ? function ()?? // 給子類添構造函數的prototype添加方法
20 ? ????{
21 ? ????????alert( this .name? + ? " ?$ " ? + ? this .salary);
22 ? ????};
23 ?
24 ? ???? var ?BillGates? = ? new ?Person( " Bill?Gates " );??? // 創建基類Person的BillGates對象
25 ? ???? var ?SteveJobs? = ? new ?Employee( " Steve?Jobs " ,? 1234 );??? // 創建子類Employee的SteveJobs對象
26 ?
27 ? ????BillGates.SayHello();??????? // 通過對象直接調用到prototype的方法
28 ? ????SteveJobs.SayHello();??????? // 通過子類對象直接調用基類prototype的方法,關注!
29 ? ????SteveJobs.ShowMeTheMoney();? // 通過子類對象直接調用子類prototype的方法
30 ?
31 ? ????alert(BillGates.SayHello? == ?SteveJobs.SayHello);? // 顯示:true,表明prototype的方法是共享的 這段代碼的第17行,構造了一個基類的對象,并將其設為子類構造函數的prototype,這是很有意思的。這樣做的目的就是為了第28行,通過子類對象也可以直接調用基類prototype的方法。為什么可以這樣呢?

原來,在JavaScript中,prototype不但能讓對象共享自己財富,而且prototype還有尋根問祖的天性,從而使得先輩們的遺產可以代 代相傳。當從一個對象那里讀取屬性或調用方法時,如果該對象自身不存在這樣的屬性或方法,就會去自己關聯的prototype對象那里尋找;如果 prototype沒有,又會去prototype自己關聯的前輩prototype那里尋找,直到找到或追溯過程結束為止。

在JavaScript內部,對象的屬性和方法追溯機制是通過所謂的prototype鏈來實現的。當用new操作符構造對象時,也會同時將構造函數的 prototype對象指派給新創建的對象,成為該對象內置的原型對象。對象內置的原型對象應該是對外不可見的,盡管有些瀏覽器(如Firefox)可以 讓我們訪問這個內置原型對象,但并不建議這樣做。內置的原型對象本身也是對象,也有自己關聯的原型對象,這樣就形成了所謂的原型鏈

在原型鏈的最末端,就是Object構造函數prototype屬性指向的那一個原型對象。這個原型對象是所有對象的最老祖先,這個老祖宗實現了諸如 toString等所有對象天生就該具有的方法。其他內置構造函數,如Function, Boolean, String, Date和RegExp等的prototype都是從這個老祖宗傳承下來的,但他們各自又定義了自身的屬性和方法,從而他們的子孫就表現出各自宗族的那些 特征。

這不就是“繼承”嗎?是的,這就是“繼承”,是JavaScript特有的“原型繼承”。

“原型繼承”是慈祥而又嚴厲的。原形對象將自己的屬性和方法無私地貢獻給孩子們使用,也并不強迫孩子們必須遵從,允許一些頑皮孩子按自己的興趣和愛好獨立 行事。從這點上看,原型對象是一位慈祥的母親。然而,任何一個孩子雖然可以我行我素,但卻不能動原型對象既有的財產,因為那可能會影響到其他孩子的利益。 從這一點上看,原型對象又象一位嚴厲的父親。我們來看看下面的代碼就可以理解這個意思了:
???? function ?Person(name)
????{
????????
this .name? = ?name;
????};
????
????Person.prototype.company?
= ? " Microsoft " ;? // 原型的屬性
????
????Person.prototype.SayHello?
= ? function ()?? // 原型的方法
????{
????????alert(
" Hello,?I'm? " ? + ? this .name? + ? " ?of? " ? + ? this .company);
????};
????
????
var ?BillGates? = ? new ?Person( " Bill?Gates " );
????BillGates.SayHello();???
// 由于繼承了原型的東西,規規矩矩輸出:Hello,?I'm?Bill?Gates
????
????
var ?SteveJobs? = ? new ?Person( " Steve?Jobs " );
????SteveJobs.company?
= ? " Apple " ;???? // 設置自己的company屬性,掩蓋了原型的company屬性
????SteveJobs.SayHello? = ? function ()? // 實現了自己的SayHello方法,掩蓋了原型的SayHello方法
????{
????????alert(
" Hi,? " ? + ? this .name? + ? " ?like? " ? + ? this .company? + ? " ,?ha?ha?ha? " );
????};

????SteveJobs.SayHello();???
// 都是自己覆蓋的屬性和方法,輸出:Hi,?Steve?Jobs?like?Apple,?ha?ha?ha?
????
????BillGates.SayHello();???
// SteveJobs的覆蓋沒有影響原型對象,BillGates還是按老樣子輸出 對象可以掩蓋原型對象的那些屬性和方法,一個構造函數原型對象也可以掩蓋上層構造函數原型對象既有的屬性和方法。這種掩蓋其實只是在對象自己身上創建了新的屬性和方法,只不過這些屬性和方法與原型對象的那些同名而已。JavaScript就是用這簡單的掩蓋機制實現了對象的“多態”性,與靜態對象語言的虛函數和重載(override)概念不謀而合。

然而,比靜態對象語言更神奇的是,我們可以隨時給原型對象動態添加新的屬性和方法,從而動態地擴展基類的功能特性。這在靜態對象語言中是很難想象的。我們來看下面的代碼:
???? function ?Person(name)
????{
????????
this .name? = ?name;
????};
????
????Person.prototype.SayHello?
= ? function ()?? // 建立對象前定義的方法
????{
????????alert(
" Hello,?I'm? " ? + ? this .name);
????};
????
????
var ?BillGates? = ? new ?Person( " Bill?Gates " );??? // 建立對象
????
????BillGates.SayHello();
????
????Person.prototype.Retire?
= ? function ()???? // 建立對象后再動態擴展原型的方法
????{
????????alert(
" Poor? " ? + ? this .name? + ? " ,?bye?bye! " );
????};
????
????BillGates.Retire();?
// 動態擴展的方法即可被先前建立的對象立即調用 原型擴展
如果在JavaScript內置的那些如Object和Function等函數的prototype上添加些新的方法和屬性,是不是就能擴展JavaScript的功能呢?

在AJAX技術迅猛發展的今天,許多成功的AJAX項目的JavaScript運行庫都大量擴展了內置函數的prototype功能。比如微軟的 ASP.NET AJAX,就給這些內置函數及其prototype添加了大量的新特性,從而增強了JavaScript的功能。

我們來看一段摘自MicrosoftAjax.debug.js中的代碼:
String.prototype.trim? = ? function ?String$trim()?{
????
if ?(arguments.length? !== ? 0 )? throw ?Error.parameterCount();
????
return ? this .replace( / ^\s+|\s+$ / g,? '' );
}
這段代碼就是給內置String函數的prototype擴展了一個trim方法,于是所有的String類對象都有了trim方法了。有了這個 擴展,今后要去除字符串兩端的空白,就不用再分別處理了,因為任何字符串都有了這個擴展功能,只要調用即可,真的很方便。

當然,幾乎很少有人去給Object的prototype添加方法,因為那會影響到所有的對象,除非在你的架構中這種方法的確是所有對象都需要的。

前兩年,微軟在設計AJAX類庫的初期,用了一種被稱為“閉包”(closure)的技術來模擬“類”。其大致模型如下:
???? function ?Person(firstName,?lastName,?age)
????{
????????
// 私有變量:
???????? var ?_firstName? = ?firstName;
????????
var ?_lastName? = ?lastName;

????????
// 公共變量:
???????? this .age? = ?age;

????????
// 方法:
???????? this .getName? = ? function ()
????????{
????????????
return (firstName? + ? " ? " ? + ?lastName);
????????};
????????
this .SayHello? = ? function ()
????????{
????????????alert(
" Hello,?I'm? " ? + ?firstName? + ? " ? " ? + ?lastName);
????????};
????};
????
????
var ?BillGates? = ? new ?Person( " Bill " ,? " Gates " ,? 53 );
????
var ?SteveJobs? = ? new ?Person( " Steve " ,? " Jobs " ,? 53 );
????
????BillGates.SayHello();
????SteveJobs.SayHello();
????alert(BillGates.getName()?
+ ? " ? " ? + ?BillGates.age);
????alert(BillGates.firstName);?????
// 這里不能訪問到私有變量 很顯然,這種模型的類描述特別象C#語言的描述形式,在一個構造函數里依次定義了私有成員、公共屬性和可用的方法,顯得非常優雅嘛。特別是“閉包”機制可以模擬對私有成員的保護機制,做得非常漂亮。

所謂的“閉包”,就是在構造函數體內定義另外的函數作為目標對象的方法函數,而這個對象的方法函數反過來引用外層外層函數體中的臨時變量。這使得 只要目標對象在生存期內始終能保持其方法,就能間接保持原構造函數體當時用到的臨時變量值。盡管最開始的構造函數調用已經結束,臨時變量的名稱也都消失 了,但在目標對象的方法內卻始終能引用到該變量的值,而且該值只能通這種方法來訪問。即使再次調用相同的構造函數,但只會生成新對象和方法,新的臨時變量 只是對應新的值,和上次那次調用的是各自獨立的。的確很巧妙!

但是前面我們說過,給每一個對象設置一份方法是一種很大的浪費。還有,“閉包”這種間接保持變量值的機制,往往會給JavaSript的垃圾回收 器制造難題。特別是遇到對象間復雜的循環引用時,垃圾回收的判斷邏輯非常復雜。無獨有偶,IE瀏覽器早期版本確實存在JavaSript垃圾回收方面的內 存泄漏問題。再加上“閉包”模型在性能測試方面的表現不佳,微軟最終放棄了“閉包”模型,而改用“原型”模型。

????原型模型需要一個構造函數來定義對象的成員,而方法卻依附在該構造函數的原型上。大致寫法如下:
???? // 定義構造函數
???? function ?Person(name)
????{
????????
this .name? = ?name;??? // 在構造函數中定義成員
????};
????
????
// 方法定義到構造函數的prototype上
????Person.prototype.SayHello? = ? function ()
????{
????????alert(
" Hello,?I'm? " ? + ? this .name);
????};????
????
????
// 子類構造函數
???? function ?Employee(name,?salary)
????{
????????Person.call(
this ,?name);???? // 調用上層構造函數
???????? this .salary? = ?salary;??????? // 擴展的成員
????};
????
????
// 子類構造函數首先需要用上層構造函數來建立prototype對象,實現繼承的概念
????Employee.prototype? = ? new ?Person()??? // 只需要其prototype的方法,此對象的成員沒有任何意義!
????
????
// 子類方法也定義到構造函數之上
????Employee.prototype.ShowMeTheMoney? = ? function ()
????{
????????alert(
this .name? + ? " ?$ " ? + ? this .salary);
????};
????
????
var ?BillGates? = ? new ?Person( " Bill?Gates " );
????BillGates.SayHello();????
????
????
var ?SteveJobs? = ? new ?Employee( " Steve?Jobs " ,? 1234 );
????SteveJobs.SayHello();
????SteveJobs.ShowMeTheMoney();

原型類模型雖然不能模擬真正的私有變量,而且也要分兩部分來定義類,顯得不怎么“優雅”。不過,對象間的方法是共享的,不會遇到垃圾回收問題,而且性能優于“閉包”模型。正所謂“有失必有得”嘛。

在原型模型中,為了實現類繼承,必須首先將子類構造函數的prototype設置為一個父類的對象實例。創建這個父類對象實例的目的就是為 了構成原型鏈,以起到共享上層原型方法作用。但創建這個實例對象時,上層構造函數也會給它設置對象成員,這些對象成員對于繼承來說是沒有意義的。雖然,我 們也沒有給構造函數傳遞參數,但確實創建了若干沒有用的成員,盡管其值是undefined,這也是一種浪費啊。

唉!世界上沒有完美的事情啊!

原型真諦

我們已經知道,用 var anObject = new aFunction() 形式創建對象的過程實際上可以分為三步:第一步是建立一個新對象;第二步將該對象內置的原型對象設置為構造函數prototype引用的那個原型對象;第 三步就是將該對象作為this參數調用構造函數,完成成員設置等初始化工作。對象建立之后,對象上的任何訪問和操作都只與對象自身及其原型鏈上的那串對象有關,與構造函數再扯不上關系了。換句話說,構造函數只是在創建對象時起到介紹原型對象和初始化對象兩個作用。

那么,我們能否自己定義一個對象來當作原型,并在這個原型上描述類,然后將這個原型設置給新創建的對象,將其當作對象的類呢?我們又能否將這個原型中的一個方法當作構造函數,去初始化新建的對象呢?例如,我們定義這樣一個原型對象:

???? var ?Person? = ?? // 定義一個對象來作為原型類
????{
????????Create:?
function (name,?age)?? // 這個當構造函數
????????{
????????????
this .name? = ?name;
????????????
this .age? = ?age;
????????},
????????SayHello:?
function ()?? // 定義方法
????????{
????????????alert(
" Hello,?I'm? " ? + ? this .name);
????????},
????????HowOld:?
function ()?? // 定義方法
????????{
????????????alert(
this .name? + ? " ?is? " ? + ? this .age? + ? " ?years?old. " );
????????}
????};

這個JSON形式的寫法多么象一個C#的類啊!既有構造函數,又有各種方法。如果可以用某種形式來創建對象,并將對象的內置的原型設置為上面這個“類”對象,不就相當于創建該類的對象了嗎?

但遺憾的是,我們幾乎不能訪問到對象內置的原型屬性!盡管有些瀏覽器可以訪問到對象的內置原型,但這樣做的話就只能限定了用戶必須使用那種瀏覽器。這也幾乎不可行。

那么,我們可不可以通過一個函數對象來做媒介,利用該函數對象的prototype屬性來中轉這個原型,并用new操作符傳遞給新建的對象呢?

其實,象這樣的代碼就可以實現這一目標:

???? function ?anyfunc(){};??????????? // 定義一個函數軀殼
????anyfunc.prototype? = ?Person;????? // 將原型對象放到中轉站prototype
???? var ?BillGates? = ? new ?anyfunc();?? // 新建對象的內置原型將是我們期望的原型對象

不過,這個anyfunc函數只是一個軀殼,在使用過這個軀殼之后它就成了多余的東西了,而且這和直接使用構造函數來創建對象也沒啥不同,有點不爽。

可是,如果我們將這些代碼寫成一個通用函數,而那個函數軀殼也就成了函數內的函數,這個內部函數不就可以在外層函數退出作用域后自動消亡嗎?而且,我們可以將原型對象作為通用函數的參數,讓通用函數返回創建的對象。我們需要的就是下面這個形式:

???? function ?New(aClass,?aParams)???? // 通用創建函數
????{
????????
function ?new_()????? // 定義臨時的中轉函數殼
????????{
????????????aClass.Create.apply(
this ,?aParams);??? // 調用原型中定義的的構造函數,中轉構造邏輯及構造參數
????????};
????????new_.prototype?
= ?aClass;???? // 準備中轉原型對象
???????? return ? new ?new_();?????????? // 返回建立最終建立的對象
????};
????
????
var ?Person? = ???????? // 定義的類
????{
????????Create:?
function (name,?age)
????????{
????????????
this .name? = ?name;
????????????
this .age? = ?age;
????????},
????????SayHello:?
function ()
????????{
????????????alert(
" Hello,?I'm? " ? + ? this .name);
????????},
????????HowOld:?
function ()
????????{
????????????alert(
this .name? + ? " ?is? " ? + ? this .age? + ? " ?years?old. " );
????????}
????};
????
????
var ?BillGates? = ?New(Person,?[ " Bill?Gates " ,? 53 ]);?? // 調用通用函數創建對象,并以數組形式傳遞構造參數
????BillGates.SayHello();
????BillGates.HowOld();

????alert(BillGates.constructor?
== ?Object);????? // 輸出:true

這里的通用函數New()就是一個“語法甘露”!這個語法甘露不但中轉了原型對象,還中轉了構造函數邏輯及構造參數。

有趣的是,每次創建完對象退出New函數作用域時,臨時的new_函數對象會被自動釋放。由于new_的prototype屬性被設置為新的原型 對象,其原來的原型對象和new_之間就已解開了引用鏈,臨時函數及其原來的原型對象都會被正確回收了。上面代碼的最后一句證明,新創建的對象的 constructor屬性返回的是Object函數。其實新建的對象自己及其原型里沒有constructor屬性,那返回的只是最頂層原型對象的構造 函數,即Object。

有了New這個語法甘露,類的定義就很像C#那些靜態對象語言的形式了,這樣的代碼顯得多么文靜而優雅啊!

當然,這個代碼僅僅展示了“語法甘露”的概念。我們還需要多一些的語法甘露,才能實現用簡潔而優雅的代碼書寫類層次及其繼承關系。好了,我們再來看一個更豐富的示例吧:

???? // 語法甘露:
???? var ?object? = ???? // 定義小寫的object基本類,用于實現最基礎的方法等
????{
????????isA:?
function (aType)??? // 一個判斷類與類之間以及對象與類之間關系的基礎方法
????????{
????????????
var ?self? = ? this ;
????????????
while (self)
????????????{
????????????????
if ?(self? == ?aType)
??????????????????
return ? true ;
????????????????self?
= ?self.Type;
????????????};
????????????
return ? false ;
????????}
????};
????
????
function ?Class(aBaseClass,?aClassDefine)???? // 創建類的函數,用于聲明類及繼承關系
????{
????????
function ?class_()??? // 創建類的臨時函數殼
????????{
????????????
this .Type? = ?aBaseClass;???? // 我們給每一個類約定一個Type屬性,引用其繼承的類
???????????? for ( var ?member? in ?aClassDefine)
????????????????
this [member]? = ?aClassDefine[member];???? // 復制類的全部定義到當前創建的類
????????};
????????class_.prototype?
= ?aBaseClass;
????????
return ? new ?class_();
????};
????
????
function ?New(aClass,?aParams)??? // 創建對象的函數,用于任意類的對象創建
????{
????????
function ?new_()????? // 創建對象的臨時函數殼
????????{
????????????
this .Type? = ?aClass;???? // 我們也給每一個對象約定一個Type屬性,據此可以訪問到對象所屬的類
???????????? if ?(aClass.Create)
??????????????aClass.Create.apply(
this ,?aParams);??? // 我們約定所有類的構造函數都叫Create,這和DELPHI比較相似
????????};
????????new_.prototype?
= ?aClass;
????????
return ? new ?new_();
????};

????
// 語法甘露的應用效果:????
???? var ?Person? = ?Class(object,?????? // 派生至object基本類
????{
????????Create:?
function (name,?age)
????????{
????????????
this .name? = ?name;
????????????
this .age? = ?age;
????????},
????????SayHello:?
function ()
????????{
????????????alert(
" Hello,?I'm? " ? + ? this .name? + ? " ,? " ? + ? this .age? + ? " ?years?old. " );
????????}
????});
????
????
var ?Employee? = ?Class(Person,???? // 派生至Person類,是不是和一般對象語言很相似?
????{
????????Create:?
function (name,?age,?salary)
????????{
????????????Person.Create.call(
this ,?name,?age);?? // 調用基類的構造函數
???????????? this .salary? = ?salary;
????????},
????????ShowMeTheMoney:?
function ()
????????{
????????????alert(
this .name? + ? " ?$ " ? + ? this .salary);
????????}
????});

????
var ?BillGates? = ?New(Person,?[ " Bill?Gates " ,? 53 ]);
????
var ?SteveJobs? = ?New(Employee,?[ " Steve?Jobs " ,? 53 ,? 1234 ]);
????BillGates.SayHello();
????SteveJobs.SayHello();
????SteveJobs.ShowMeTheMoney();
????
????
var ?LittleBill? = ?New(BillGates.Type,?[ " Little?Bill " ,? 6 ]);??? // 根據BillGate的類型創建LittleBill
????LittleBill.SayHello();
????
????alert(BillGates.isA(Person));???????
// true
????alert(BillGates.isA(Employee));????? // false
????alert(SteveJobs.isA(Person));??????? // true
????alert(Person.isA(Employee));???????? // false
????alert(Employee.isA(Person));???????? // true

?“語法甘露”不用太多,只要那么一點點,就能改觀整個代碼的易讀性和流暢性,從而讓代碼顯得更優雅。有了這些語法甘露,JavaScript就很像一般對象語言了,寫起代碼了感覺也就爽多了!

令人高興的是,受這些甘露滋養的JavaScript程序效率會更高因為其原型對象里既沒有了毫無用處的那些對象級的成員,而且還不存在 constructor屬性體,少了與構造函數間的牽連,但依舊保持了方法的共享性。這讓JavaScript在追溯原型鏈和搜索屬性及方法時,少費許多工夫啊

我們就把這種形式稱為“甘露模型”吧!其實,這種“甘露模型”的原型用法才是符合prototype概念的本意,才是的JavaScript原型的真諦!

原文地址:http://7685941014.blog.163.com/blog/static/124615480201061782347164/

轉載于:https://my.oschina.net/megan/blog/128353

總結

以上是生活随笔為你收集整理的javascript 编程思想的全部內容,希望文章能夠幫你解決所遇到的問題。

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

在线观看免费 | 欧美在线观看视频一区二区三区 | 日韩精品中文字幕在线观看 | 国内精品久久久久久久97牛牛 | 久久精品一区二区三区国产主播 | 国产精品少妇 | 国产精品 欧美 日韩 | 成人91在线观看 | 97超碰影视 | 精品久久久久久久久久久久 | 在线观看一区 | 久久九九九九 | 日韩视频一区二区三区 | 中文字幕在线看视频国产中文版 | 国产拍揄自揄精品视频麻豆 | 欧美巨大荫蒂茸毛毛人妖 | 午夜视频免费播放 | 少妇性bbb搡bbb爽爽爽欧美 | 国产一区精品在线观看 | 亚洲天天干 | 亚洲天堂视频在线 | 五月婷婷开心中文字幕 | 久久99国产精品二区护士 | 亚洲视频在线播放 | 免费91在线观看 | 天天天天射 | 天天操天天干天天干 | 欧美另类高清 videos | 成人一区影院 | 日韩一二区在线观看 | 97视频网址 | 97成人超碰| 麻豆小视频在线观看 | 日韩av在线一区二区 | 成人片在线播放 | 狂野欧美激情性xxxx欧美 | 在线三级av | 日韩高清一 | 日韩亚洲国产中文字幕 | 在线电影日韩 | 91桃色在线免费观看 | 美女网站色在线观看 | 午夜精品电影 | 人人爽人人澡人人添人人人人 | av在线播放亚洲 | 丁香色婷 | 国产亚洲精品久久网站 | 中文字幕a∨在线乱码免费看 | 久久综合九色 | 日韩专区av | 国产精品9999 | 中文字幕中文字幕在线中文字幕三区 | 久草精品视频在线观看 | 色视频网址| 夜夜看av | 在线观看蜜桃视频 | 久久精品一区二区三区四区 | 色网站免费在线看 | 九九免费视频 | 五月天电影免费在线观看一区 | 久久理论电影网 | 精品一区二区免费视频 | 中文永久免费观看 | 久草网站在线 | 九色福利视频 | 黄色片免费电影 | 中字幕视频在线永久在线观看免费 | 国内精品99 | 国产精品久久久久久久久久不蜜月 | 亚洲免费一级电影 | 国产资源中文字幕 | 美女视频黄色免费 | 九九欧美 | 中文字幕在线观看免费高清完整版 | 九九九电影免费看 | 黄色av一级片 | 国产免费成人av | 婷婷 中文字幕 | 99在线高清视频在线播放 | 日本黄色黄网站 | 91在线视频网址 | 天天干天天操天天做 | www激情久久| 91视频高清免费 | 久久视频精品在线观看 | 夜夜操网 | 免费热情视频 | 久久大片| 午夜精品久久久久久久爽 | 色婷婷午夜 | 久久99网 | 青青草视频精品 | 欧美极品少妇xbxb性爽爽视频 | 国产 日韩 中文字幕 | 国产美女永久免费 | 亚洲一区黄色 | 99精品热 | 久久久免费在线观看 | 国产精品久久久久久超碰 | 国产精品久久毛片 | 欧美天堂视频在线 | 日韩高清在线观看 | 久久一区二区三区超碰国产精品 | 久久精品欧美一区二区三区麻豆 | 欧美精品亚洲精品日韩精品 | 激情欧美一区二区三区免费看 | 午夜国产成人 | 91av色| 人人插超碰 | 在线免费观看国产 | 国产午夜三级 | 日本精品视频一区二区 | 日韩精品一区二区三区免费观看 | 在线观看精品视频 | 亚洲国产大片 | 日本乱视频 | 粉嫩av一区二区三区四区五区 | 久久精品欧美一区二区三区麻豆 | 在线亚洲日本 | 日韩精品一卡 | 色婷婷色 | 国产精品久免费的黄网站 | 亚洲1区在线 | 伊人春色电影网 | 欧美在一区 | 色综合天天色 | 69国产成人综合久久精品欧美 | 夜夜躁日日躁狠狠久久av | 日日夜色 | 91九色蝌蚪视频 | 色在线最新 | 国产精品久久久久久一区二区 | 最近高清中文在线字幕在线观看 | 日本性视频 | 午夜av免费观看 | 国产精品资源在线 | 日韩小视频网站 | 91传媒激情理伦片 | 久久国语露脸国产精品电影 | 在线观看av黄色 | 成人小视频在线播放 | 国产麻豆精品久久一二三 | 国产精品久久久久久久毛片 | 欧美日韩亚洲在线观看 | 九九九在线 | 国产免费一区二区三区最新6 | 欧美孕妇视频 | 欧美不卡视频在线 | 日韩免费看 | 日韩在线观看第一页 | 欧美黄在线 | 国产精品一区二区三区观看 | 在线免费性生活片 | 亚洲精品国精品久久99热 | 婷婷丁香在线观看 | 一级片免费观看视频 | 91在线看片| 国产精品va在线播放 | 国产精品女主播一区二区三区 | a天堂最新版中文在线地址 久久99久久精品国产 | 啪啪av在线 | 精品一区二区电影 | 日日夜夜操操操操 | 一区 二区 精品 | 日韩免费一区二区三区 | 日韩欧美一区二区三区在线观看 | 久久免费电影网 | 成人久久久久久久久久 | 特级西西444www高清大视频 | 91精品推荐 | 久久黄色精品视频 | 九九国产精品视频 | 国产生活一级片 | 国产成人777777 | 国产一区二区在线观看免费 | 欧美日韩午夜爽爽 | 国产精品久久电影观看 | 黄色福利| 人人cao| 香蕉久草在线 | 久久人人97超碰国产公开结果 | 91私密视频 | 国产午夜三级一区二区三 | 99re久久资源最新地址 | 深夜精品福利 | 亚洲精品乱码白浆高清久久久久久 | 久久久午夜精品理论片中文字幕 | 日韩欧美成人网 | 久久激情视频 久久 | 午夜精品视频免费在线观看 | 日韩av一区二区在线影视 | 国产一区二区三区四区在线 | 97人人模人人爽人人少妇 | 久久精品亚洲综合专区 | 国产精品高清一区二区三区 | 欧美另类交在线观看 | 亚洲国产精品成人女人久久 | a级免费观看 | 国产一级二级视频 | 最近2019年日本中文免费字幕 | 日产av在线播放 | 色av男人的天堂免费在线 | av在线一级 | 久久精品一区二区三区视频 | 一级免费看视频 | 亚洲精品综合一区二区 | av一级片在线观看 | 国产精品久久久影视 | 欧美日韩精品电影 | 欧美日韩久久不卡 | 午夜视频导航 | 久久精品视频在线免费观看 | 黄色免费电影网站 | 2023亚洲精品国偷拍自产在线 | 69夜色精品国产69乱 | 中文字幕中文字幕在线中文字幕三区 | 在线 国产一区 | 婷婷在线看 | 国产精品久久久久久久久久久久午夜 | 一区二区三区在线不卡 | 国内精品国产三级国产aⅴ久 | 欧美日韩在线电影 | 久久精品国产免费看久久精品 | 999久久久免费视频 午夜国产在线观看 | 国产又黄又硬又爽 | 国产精品18久久久久久久网站 | 激情五月五月婷婷 | 在线观看欧美成人 | 黄色精品久久久 | 亚洲自拍自偷 | 精品日韩中文字幕 | 国产精品99久久久久久小说 | 久久这里只有精品9 | 久久久影院官网 | 四虎免费在线观看视频 | 国产超碰97 | 久久九九九九 | 九九热在线视频 | 中文字幕在线观看免费 | 美女国产网站 | 午夜精品久久久久久久久久久久久久 | 久久久www成人免费精品张筱雨 | 国产资源av | 日韩av区| 少妇bbbb搡bbbb桶 | 国产精品99久久久久久久久久久久 | 日韩高清av在线 | 免费网址在线播放 | 天天色天 | 少妇bbbb搡bbbb桶 | 午夜久久福利影院 | 欧美日韩免费观看一区=区三区 | 在线一区电影 | 国产精品久久久久久久久久了 | 99精品欧美一区二区三区黑人哦 | www.黄色小说.com | 91免费网站在线观看 | 欧美日本在线观看视频 | 成人资源网| 国产一级一片免费播放放a 一区二区三区国产欧美 | 国产手机在线播放 | 免费av黄色 | 日韩精品久久中文字幕 | 综合久久久久久久 | 欧美一级专区免费大片 | 中文字幕在线观看免费观看 | 日韩午夜视频在线观看 | 日韩av在线资源 | 最近中文字幕免费视频 | 日本aa在线 | 91成人区| 久久久久亚洲天堂 | 久久久免费毛片 | 91av看片| 狠狠天天| 337p日本欧洲亚洲大胆裸体艺术 | 精品在线观看免费 | 国产视频在线一区二区 | 午夜黄色一级片 | 成人黄色大片在线观看 | 国产精品初高中精品久久 | 国产成人精品免费在线观看 | 在线观看精品 | 国产又粗又猛又色又黄视频 | 一区二区三区在线免费播放 | 国产大片黄色 | 亚洲九九 | 99精品在线免费在线观看 | 国产一区二区在线免费视频 | 黄色av网站在线免费观看 | 欧美成人h版在线观看 | 狠狠干天天操 | 欧美精品久久久久 | 久久色中文字幕 | 一区二区在线不卡 | www.狠狠插.com | 精品在线小视频 | 国产视频在线免费 | 免费影视大全推荐 | 人人超碰免费 | 久久久久久国产精品999 | 超碰在线日韩 | 色综合久久中文综合久久牛 | 天天躁日日躁狠狠躁av麻豆 | 婷婷去俺也去六月色 | 久草视频视频在线播放 | 精品国产伦一区二区三区观看体验 | 日韩欧美一区二区三区在线观看 | 丝袜网站在线观看 | 免费视频国产 | 亚洲天堂精品视频在线观看 | 亚洲精品免费在线 | 五月婷婷av在线 | 亚洲韩国一区二区三区 | 久久一区二区免费视频 | 欧美精品一区二区免费 | 国产在线播放观看 | 久久精品视频3 | 一级片免费观看视频 | 国产精品久久久一区二区 | 国产精品久久久久久妇 | 毛片网站在线 | 久久精品超碰 | 日韩免费视频一区二区 | 国产精品久久久久婷婷 | 日韩欧美在线免费 | 久久精品久久精品久久 | 免费观看日韩 | av资源网在线播放 | 日批网站在线观看 | 亚洲欧美视频在线观看 | 日韩av资源在线观看 | 国产一线二线三线性视频 | 97国产小视频 | 综合久久影院 | www久久精品| 国产精品亚洲视频 | 精品视频国产 | 中文av字幕在线观看 | 久久香蕉电影 | 人人爽人人爽人人爽人人爽 | 久久精品美女视频 | 久久久久国产精品www | 色噜噜日韩精品一区二区三区视频 | 久久久精品视频成人 | 日本性视频 | 一区二区三区四区不卡 | 中文在线8新资源库 | 久久久久久久久久亚洲精品 | 欧美亚洲一区二区在线 | 97成人啪啪网 | 亚洲国产精品久久久久 | 亚洲欧美综合精品久久成人 | 99久久精品国 | 不卡国产在线 | 麻豆91精品91久久久 | 在线播放 日韩专区 | 狠狠干婷婷色 | 久久中文字幕视频 | 黄色小说视频在线 | 色综合激情网 | 丁香综合av| 日韩在线视频精品 | 日韩欧美有码在线 | 免费av在线 | 91人人揉日日捏人人看 | 人人干天天干 | 91一区二区三区久久久久国产乱 | 欧美日韩天堂 | 久青草视频 | 一区二区三区中文字幕在线观看 | 91在线免费播放视频 | a级国产毛片 | 亚洲欧洲av在线 | 国产精品视频资源 | 欧美激情另类 | 精品国产视频在线 | 麻豆激情电影 | 麻豆果冻剧传媒在线播放 | 2023av在线| 成年人毛片在线观看 | 欧美一区日韩一区 | 国产黄色在线 | 久久综合色天天久久综合图片 | 成人黄大片视频在线观看 | 精品一区电影 | 久久影视中文字幕 | 国产精品黑丝在线观看 | 亚洲乱码在线 | zzijzzij亚洲成熟少妇 | 婷婷视频在线观看 | 在线观看国产麻豆 | 中文字幕视频在线播放 | 99久久爱 | 日韩女同一区二区三区在线观看 | 亚洲jizzjizz日本少妇 | 丁香花中文在线免费观看 | 99精品视频在线播放免费 | 国产精品久久久久久久久蜜臀 | 亚洲电影久久久 | 日本午夜在线亚洲.国产 | 国产成人av电影在线观看 | 日韩欧美精品免费 | 91福利试看 | 久草在线观看视频免费 | 女人18片 | 这里只有精品视频在线观看 | 超级碰碰免费视频 | 日韩高清在线观看 | 深爱激情五月婷婷 | 国产一二区视频 | 91av视频在线播放 | 国产老太婆免费交性大片 | 欧美巨乳波霸 | 视频99爱 | 人人玩人人添人人澡97 | 黄色成人在线 | 欧美在线视频一区二区 | 国产美女免费 | 久久国产美女视频 | 91超碰在线播放 | 精品中文字幕在线观看 | 亚洲资源在线网 | 黄色网中文字幕 | 久久久久综合网 | 久草观看| 东方av在 | 成人精品视频久久久久 | 欧美精品午夜 | 2017狠狠干 | 亚洲精品国产精品国自 | 欧美日韩在线网站 | 亚洲精品午夜国产va久久成人 | 亚洲欧洲一级 | 国产福利免费在线观看 | 久久久国产精品人人片99精片欧美一 | 人人舔人人 | 99色 | 欧美激情在线看 | 成人毛片在线观看 | 久久精品国产免费看久久精品 | 在线免费色 | 丁香婷婷激情国产高清秒播 | 欧美做受xxx | 四虎成人在线 | 精品日本视频 | 日韩av看片 | 欧美地下肉体性派对 | 香蕉影院在线播放 | 成人免费看视频 | 人人爽人人澡人人添人人人人 | 久久视频免费观看 | 久久精品电影网 | 亚洲国产精品va在线看 | 麻花天美星空视频 | 日韩综合一区二区 | 91人人视频在线观看 | 一区免费视频 | 久久人人看| 在线观看欧美成人 | 99热在线精品观看 | 成人小视频在线观看免费 | 69国产精品视频 | 99热只有精品在线观看 | 精品不卡av| 97在线播放 | 久久在线播放 | 欧美激情视频一区二区三区免费 | 一区二区三区动漫 | 久久九九影视网 | 国产主播大尺度精品福利免费 | 国产精品中文字幕在线播放 | 最近最新中文字幕视频 | 久久免视频 | 国产亚洲视频系列 | 久久午夜国产 | 亚洲精品国产自产拍在线观看 | 亚洲国产欧美在线人成大黄瓜 | 91av电影| 欧美性色综合网站 | 亚洲国产精品成人女人久久 | 天天插狠狠插 | 综合网中文字幕 | 91精彩在线视频 | 日韩精品资源 | 国产精品久久久久久久久软件 | 日韩中文字幕视频在线观看 | 久草免费色站 | 中文字幕乱码亚洲精品一区 | av在线色 | 成人动图 | 午夜精品电影一区二区在线 | 六月丁香激情综合 | 丁香 久久 综合 | 在线一二三四区 | 狠狠的操| 国产精品高潮在线观看 | 久久国产乱 | 丁香花中文在线免费观看 | 毛片网在线 | 夜夜看av| 国产视频资源在线观看 | 午夜视频播放 | 久草在线免费色站 | 国产高清视频网 | 国产中文字幕亚洲 | 96久久欧美麻豆网站 | 91精品久久香蕉国产线看观看 | 免费在线观看日韩视频 | 91超国产 | 99日韩精品 | av+在线播放在线播放 | 日韩精品久久一区二区三区 | 综合色天天 | 少妇资源站 | 五月天丁香视频 | 久久五月婷婷丁香 | 日韩av一区二区三区 | 91在线免费看片 | 色婷婷狠狠 | 亚洲精品久久久久999中文字幕 | 色多多视频在线观看 | 国产三级久久久 | 日韩av免费在线电影 | www.91av在线| 国产一区二区不卡视频 | 久久精品久久久久 | 在线观看亚洲视频 | 国产日韩精品一区二区 | 四虎影视精品 | 精品国产三级a∨在线欧美 免费一级片在线观看 | 久久艹国产视频 | 天天摸日日操 | 日韩av电影中文字幕在线观看 | 中文字幕综合在线 | 日韩欧美69| 久久超级碰 | www久久国产 | 久久8| 国产女人40精品一区毛片视频 | 欧美黑吊大战白妞欧美 | 久久综合五月天 | 激情电影在线观看 | 中文字幕国产精品一区二区 | 香蕉视频在线播放 | 亚洲va欧美va人人爽 | 日日干av | 日韩欧美一区二区三区在线观看 | av中文天堂在线 | 日韩二区三区在线 | 天堂黄色片 | 国产成人黄色网址 | 黄色在线观看免费 | 91在线精品一区二区 | 黄色精品一区二区 | 五月婷婷激情网 | 日韩mv欧美mv国产精品 | 久久久久免费网 | 成人在线免费视频 | 91自拍91 | 中文字幕在线观看2018 | 波多野结衣一区三区 | 中文字幕人成不卡一区 | 色妞久久福利网 | 美女av电影 | 99人成在线观看视频 | 在线观看免费黄色 | 热re99久久精品国产66热 | 国产美女免费视频 | avhd高清在线谜片 | 欧美另类交人妖 | 激情偷乱人伦小说视频在线观看 | 久久人人爽人人人人片 | www.99av| 亚洲精品成人av在线 | 国产精品成人免费一区久久羞羞 | 久操久| 精品久久久国产 | 91精品国自产在线观看 | 天天综合区 | 精品在线二区 | 久久激情日本aⅴ | 密桃av在线 | 日韩免费高清在线 | 伊人天天狠天天添日日拍 | 黄色a大片 | 精品免费一区 | 亚洲精品网站 | 久久久人| 97视频免费在线观看 | 伊人中文在线 | 国产精品色| 日色在线视频 | aa级黄色大片 | 日韩午夜高清 | 国产精品自在线拍国产 | 天天色天天操天天爽 | 精品国产乱码久久久久久1区2匹 | 国产精品不卡在线 | 波多野结衣一区二区三区中文字幕 | 欧美一区二区三区免费观看 | 中日韩男男gay无套 日韩精品一区二区三区高清免费 | 日本久久高清视频 | 国产九九在线 | 亚洲精品tv久久久久久久久久 | 亚洲高清视频在线观看免费 | 国产成人av网址 | 久久免费电影 | 久草视频手机在线 | 国产一区不卡在线 | 久草在线99 | 久久99国产精品久久99 | 欧美日韩精品在线播放 | 狠狠操夜夜 | 国模一区二区三区四区 | 免费在线播放 | 超级碰视频 | 日韩成人av在线 | 91看片在线播放 | 亚洲精品国产精品国自产观看 | 97超碰成人 | av黄色av| 天天舔天天搞 | 亚洲精品91天天久久人人 | 欧美性猛片, | 中文在线字幕观看电影 | 国产大陆亚洲精品国产 | 色黄久久久久久 | 欧美日韩国产综合一区二区 | 91av视频免费在线观看 | 欧美福利精品 | 日韩福利在线观看 | 欧美日韩在线视频一区二区 | 精品一区 在线 | 国产视频精品久久 | 中文字幕资源在线 | 一区二区三区手机在线观看 | 一本色道久久综合亚洲二区三区 | 国产一级片免费观看 | 91麻豆精品 | 国产18精品乱码免费看 | 国产啊v在线观看 | 亚州激情视频 | 激情综合五月网 | 手机成人av在线 | 亚洲第一区精品 | 热久久视久久精品18亚洲精品 | 日本精品久久 | 超碰在线天天 | 久操视频在线免费看 | 97在线观看免费高清完整版在线观看 | 久草在线精品观看 | 国产精品专区h在线观看 | 韩日精品中文字幕 | 夜添久久精品亚洲国产精品 | 91最新中文字幕 | 高清在线一区 | 国产日韩欧美视频 | 国产精品专区h在线观看 | 成人h电影 | 国产视频久久 | 九九视频免费在线观看 | 久久久99久久| 人人干人人艹 | 香蕉色综合 | 最新中文字幕在线观看视频 | 黄色大片免费播放 | 国产一区二区三区高清播放 | 亚洲精品国产精品国自 | 日韩毛片在线免费观看 | 成人国产精品一区二区 | 人人爽人人爽人人爽人人爽 | 亚洲永久免费av | 噜噜色官网 | 日本精品xxxx | 欧美三人交| 国产精品丝袜久久久久久久不卡 | 欧美日韩国产在线精品 | 国产视频999| 日韩精品一区二区三区水蜜桃 | 在线免费观看亚洲视频 | 天天操网站 | 日韩中文在线视频 | 一区二区三区免费 | 91在线操| 国产精品女同一区二区三区久久夜 | 亚洲第一久久久 | 日韩www在线 | 国产黄色片在线 | 国产成人精品免高潮在线观看 | 超碰在线观看97 | 97在线看片 | 久久亚洲福利 | 久久国产精品区 | 日韩最新中文字幕 | 精品一区久久 | 国产精品精品视频 | 九九久久久久久久久激情 | 免费av网址在线观看 | zzijzzij亚洲成熟少妇 | 国产一区成人在线 | 日韩小视频网站 | 国产精品视频内 | 国内精品久久久久久久久久 | 国产玖玖在线 | 亚洲精品av在线 | 亚洲黄色免费在线 | 成人av免费看 | 91麻豆免费版 | 久久久久久久看片 | 国产91精品一区二区麻豆亚洲 | 精品久久久久免费极品大片 | 亚洲狠狠操| 日日夜精品 | 在线国产不卡 | 三级黄色理论片 | 久久久99精品免费观看乱色 | 99久久精品国产观看 | 国产黄免费 | 国产综合久久 | 精品国产成人av在线免 | 麻豆视频大全 | 992tv人人网tv亚洲精品 | 久久一级电影 | av线上看 | 一区中文字幕电影 | 在线观av | 性色va| 最近中文字幕免费观看 | 奇米先锋| 国产精品美女久久久久久2018 | 国产在线观看免费 | 亚洲人在线7777777精品 | 免费看成人 | 欧美精品xxx | 久草在线视频精品 | 久久免费黄色网址 | 国产精品密入口果冻 | 午夜12点| 久久婷婷一区二区三区 | 在线色视频小说 | 人人射人人插 | 久久精品电影院 | 五月婷婷黄色 | 高清久久久 | 国产精品黄色在线观看 | 香蕉影院在线播放 | 91漂亮少妇露脸在线播放 | 999成人网 | 亚洲一级片在线看 | 中文字幕av最新更新 | 激情网婷婷 | 国产精品乱看 | 久久久久免费 | 亚洲欧美一区二区三区孕妇写真 | 亚洲精品99| 欧美日韩精品在线观看 | 男女啪啪视屏 | 婷五月激情 | 亚洲综合国产精品 | 久久99精品国产 | 久久精品导航 | 麻豆免费在线播放 | 公与妇乱理三级xxx 在线观看视频在线观看 | 色婷婷丁香| 69xxxx欧美 | 中文字幕人成不卡一区 | 日韩高清一二三区 | 中文字幕一区二区三区久久蜜桃 | 国产精品国产三级国产不产一地 | 午夜精品中文字幕 | 激情综合五月天 | 国产一级在线免费观看 | 色午夜影院 | 国产精品一区二区62 | 免费在线观看污网站 | 日本字幕网 | 国产香蕉久久精品综合网 | 一本一本久久aa综合精品 | 婷婷六月综合亚洲 | 欧美午夜性 | 精品久久网 | 日韩精品最新在线观看 | 国产 欧美 日韩 | 91视频麻豆 | 久久久久久久99精品免费观看 | 精品国产一区二区在线 | 久草免费色站 | 久久精品5 | 精品免费久久久久久 | 九九精品视频在线观看 | 久久精品一区二区三区四区 | 久久999精品| 天天曰天天爽 | 成人免费观看完整版电影 | 亚洲精品乱码久久久久久高潮 | 国产精品久久久久永久免费观看 | 午夜av影院 | 丁香六月中文字幕 | 激情五月婷婷综合 | 青草视频在线播放 | 色综合久久久久综合 | 国产精品久久久久久五月尺 | 久久99精品久久久久婷婷 | 深爱五月激情网 | 96精品高清视频在线观看软件特色 | 久久亚洲在线 | 色a4yy| 午夜精品久久一牛影视 | 久久久久久久久久久电影 | 国产精品美女久久久久久久 | 中文字幕国产一区二区 | 久久久www成人免费精品张筱雨 | 国产一区二区免费 | 国产精品美女999 | www激情com| 欧美在线一| 天天干,天天干 | 97视频在线免费播放 | 国内成人综合 | 九九久久成人 | 全黄色一级片 | 日韩一二三区不卡 | 探花视频在线观看免费 | 久久97久久 | 色多多污污在线观看 | 成片人卡1卡2卡3手机免费看 | 色网站中文字幕 | 成人一级在线 | 天天操夜夜爱 | 中文字幕在线观看第三页 | 天天操福利视频 | av免费播放 | 国产色啪| 97超碰成人 | 久久成人久久 | av一级片网站 | 日韩手机视频 | 亚洲影院色 | 久久精彩视频 | 亚洲精品 在线视频 | 久久久99精品免费观看app | 999电影免费在线观看 | 欧美日韩高清国产 | 最新av在线免费观看 | 男女拍拍免费视频 | 麻豆网站免费观看 | 麻豆视频在线观看免费 | 日韩最新中文字幕 | 天天干天天干天天射 | 国产黄 | 69精品人人人人 | 日韩午夜精品福利 | 99视频在线免费播放 | 国产在线精品视频 | 日韩欧美一区二区三区在线观看 | 国产成视频在线观看 | 国产高清免费在线观看 | 免费特级黄色片 | 99精品视频一区二区 | 麻豆激情电影 | 一区二区理论片 | 日本丰满少妇免费一区 | 久操视频在线免费看 | 国产精品美乳一区二区免费 | 美女福利视频网 | 国产一区av在线 | 热久久精品在线 | 人人爽人人爱 | 麻豆传媒视频在线 | 97精品国自产拍在线观看 | 亚洲更新最快 | 久久精品理论 | 天天综合色 | 免费中文字幕 | 免费精品在线观看 | 国产一级电影免费观看 | av在线免费观看不卡 | 狠狠狠狠狠狠天天爱 | 国产精品女人网站 | a级片在线播放 | av中文字幕网站 | 91亚瑟视频 | 在线看日韩 | 久久影视一区二区 | 免费av免费观看 | 国产小视频在线看 | 色婷婷狠| 免费午夜视频在线观看 | 日本中文字幕一二区观 | 最近日韩中文字幕中文 | av电影不卡 | 鲁一鲁影院| 日韩中文字幕一区 | 欧美日韩亚洲在线 | 麻豆免费看片 | 日日婷婷夜日日天干 | 欧美永久视频 | 中文字幕在线看片 | 狠狠色丁婷婷日日 | 992tv人人网tv亚洲精品 | 亚洲2019精品 | 国产一二三区在线观看 | 黄色视屏免费在线观看 | 国产色在线| 亚洲伊人av | 亚洲视频电影在线 | 日韩免费看的电影 | 亚洲一二区视频 | 狠狠色狠狠色综合日日小说 | 狠狠狠干 | 99爱视频| 久久久久久久99精品免费观看 | 亚洲国产欧美一区二区三区丁香婷 | 97国产精品亚洲精品 | 久久国产精品99国产精 | 国产精品九九九九九 | 中文字幕在线播放日韩 | 久久久精品国产一区二区电影四季 | 成人黄色电影在线播放 | 久久精品网 | 91视频观看免费 | 99高清视频有精品视频 | 日韩欧美一级二级 | 最近日本中文字幕 | 综合色婷婷 | 国产精品毛片久久久久久 | 久久兔费看a级 | 九九九免费视频 | 四虎国产精品永久在线国在线 | 91丨九色丨首页 | 成 人 免费 黄 色 视频 | 91麻豆看国产在线紧急地址 | 狠狠久久 | 中文字幕在线观看网 | 欧美日韩午夜爽爽 | 人人爽人人爽人人爽人人爽 | 视频国产一区二区三区 | 91精品999 | 日韩在线精品一区 | 在线成人中文字幕 | 亚洲精品一区中文字幕乱码 | 超碰免费在线公开 | 国产精品久久久亚洲 | 狠狠88综合久久久久综合网 | 久久高清 | 成人蜜桃视频 | 狠狠色免费| 久草av在线播放 | 久久久久久不卡 | 午夜视频在线观看一区 | 亚洲无吗av | 日韩在线小视频 | 99久久www| 精品国产一区二区三区不卡 | 国产一区欧美一区 | 国产在线精品观看 | 亚洲综合情| 成人av午夜 | 涩涩网站在线观看 | 九九九九热精品免费视频点播观看 | 亚洲无线视频 | 9草在线 | 午夜视频在线观看一区二区三区 | 日韩精品短视频 | 欧美一级专区免费大片 | 97在线资源 | 911久久| 97国产超碰 | 香蕉视频网址 | 国产一区二区三区久久久 | 国产欧美高清 | 色999视频| 狠狠干美女 | 天天射天天舔天天干 | 91污在线观看 | 米奇狠狠狠888 | 91在线小视频 | 玖玖玖国产精品 | 午夜精品视频在线 | 国产视频中文字幕在线观看 | 一级免费黄视频 | 久久蜜桃av | 中文字幕免费久久 | 天天操天天射天天插 | 五月婷婷六月综合 | 美女在线免费观看视频 | 91在线精品秘密一区二区 | av久久在线| 99国内精品久久久久久久 | 在线免费观看黄色大片 | 亚洲精品视频久久 | 色噜噜狠狠狠狠色综合 | 日韩精品视频在线观看网址 | 久久99国产精品免费 | 丁香视频在线观看 | 在线观看免费色 | 青青河边草观看完整版高清 |