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

深入理解JS作用域和作用域鏈

開發(fā) 前端
本文我會(huì)盡我所能用最簡(jiǎn)單的方式來解釋作用域和作用域鏈,希望大家有所收獲!

 [[386247]]

前言

JavaScript 中有一個(gè)被稱為作用域(Scope)的特性。雖然對(duì)于許多新手開發(fā)者來說,作用域的概念并不是很容易理解,本文我會(huì)盡我所能用最簡(jiǎn)單的方式來解釋作用域和作用域鏈,希望大家有所收獲!

作用域(Scope)

1.什么是作用域

作用域是在運(yùn)行時(shí)代碼中的某些特定部分中變量,函數(shù)和對(duì)象的可訪問性。換句話說,作用域決定了代碼區(qū)塊中變量和其他資源的可見性。可能這兩句話并不好理解,我們先來看個(gè)例子: 

  1. 1function outFun2() {  
  2. 2    var inVariable = "內(nèi)層變量2" 
  3. 3}  
  4. 4outFun2();//要先執(zhí)行這個(gè)函數(shù),否則根本不知道里面是啥  
  5. 5console.log(inVariable); // Uncaught ReferenceError: inVariable is not defined 

從上面的例子可以體會(huì)到作用域的概念,變量inVariable在全局作用域沒有聲明,所以在全局作用域下取值會(huì)報(bào)錯(cuò)。我們可以這樣理解:作用域就是一個(gè)獨(dú)立的地盤,讓變量不會(huì)外泄、暴露出去。也就是說作用域最大的用處就是隔離變量,不同作用域下同名變量不會(huì)有沖突。

ES6 之前 JavaScript 沒有塊級(jí)作用域,只有全局作用域和函數(shù)作用域。ES6的到來,為我們提供了‘塊級(jí)作用域’,可通過新增命令let和const來體現(xiàn)。

2.全局作用域和函數(shù)作用域

在代碼中任何地方都能訪問到的對(duì)象擁有全局作用域,一般來說以下幾種情形擁有全局作用域:

  •  最外層函數(shù) 和在最外層函數(shù)外面定義的變量擁有全局作用域 
  1.  1var outVariable = "我是最外層變量"; //最外層變量  
  2.  2function outFun() { //最外層函數(shù)  
  3.  3    var inVariable = "內(nèi)層變量" 
  4.  4    function innerFun() { //內(nèi)層函數(shù)  
  5.  5        console.log(inVariable);  
  6.  6    }  
  7.  7    innerFun();  
  8.  8}  
  9.  9console.log(outVariable); //我是最外層變量  
  10. 10outFun(); //內(nèi)層變量  
  11. 11console.log(inVariable); //inVariable is not defined 
  12. 12innerFun(); //innerFun is not defined 
  •  所有末定義直接賦值的變量自動(dòng)聲明為擁有全局作用域 
  1. 1function outFun2() {  
  2. 2    variable = "未定義直接賦值的變量" 
  3. 3    var inVariable2 = "內(nèi)層變量2" 
  4. 4}  
  5. 5outFun2();//要先執(zhí)行這個(gè)函數(shù),否則根本不知道里面是啥  
  6. 6console.log(variable); //未定義直接賦值的變量  
  7. 7console.log(inVariable2); //inVariable2 is not defined 
  •  所有window對(duì)象的屬性擁有全局作用域

一般情況下,window對(duì)象的內(nèi)置屬性都擁有全局作用域,例如window.name、window.location、window.top等等。

全局作用域有個(gè)弊端:如果我們寫了很多行 JS 代碼,變量定義都沒有用函數(shù)包括,那么它們就全部都在全局作用域中。這樣就會(huì) 污染全局命名空間, 容易引起命名沖突。 

  1. 1// 張三寫的代碼中  
  2. 2var data = {a: 100}  
  3.  
  4. 4// 李四寫的代碼中  
  5. 5var data = {x: true} 

這就是為何 jQuery、Zepto 等庫(kù)的源碼,所有的代碼都會(huì)放在(function(){....})()中。因?yàn)榉旁诶锩娴乃凶兞浚疾粫?huì)被外泄和暴露,不會(huì)污染到外面,不會(huì)對(duì)其他的庫(kù)或者 JS 腳本造成影響。這是函數(shù)作用域的一個(gè)體現(xiàn)。

函數(shù)作用域,是指聲明在函數(shù)內(nèi)部的變量,和全局作用域相反,局部作用域一般只在固定的代碼片段內(nèi)可訪問到,最常見的例如函數(shù)內(nèi)部。 

  1. 1function doSomething(){  
  2. 2    var blogName="浪里行舟" 
  3. 3    function innerSay(){  
  4. 4        alert(blogName);  
  5. 5    }  
  6. 6    innerSay();  
  7. 7}  
  8. 8alert(blogName); //腳本錯(cuò)誤  
  9. 9innerSay(); //腳本錯(cuò)誤 

作用域是分層的,內(nèi)層作用域可以訪問外層作用域的變量,反之則不行。我們看個(gè)例子,用泡泡來比喻作用域可能好理解一點(diǎn):

最后輸出的結(jié)果為 2, 4, 12

  •  泡泡1是全局作用域,有標(biāo)識(shí)符foo;
  •  泡泡2是作用域foo,有標(biāo)識(shí)符a,bar,b;
  •  泡泡3是作用域bar,僅有標(biāo)識(shí)符c。

值得注意的是:塊語句(大括號(hào)“{}”中間的語句),如 if 和 switch 條件語句或 for 和 while 循環(huán)語句,不像函數(shù),它們不會(huì)創(chuàng)建一個(gè)新的作用域。在塊語句中定義的變量將保留在它們已經(jīng)存在的作用域中。 

  1. 1if (true) {  
  2. 2    // 'if' 條件語句塊不會(huì)創(chuàng)建一個(gè)新的作用域  
  3. 3    var name = 'Hammad'; // name 依然在全局作用域中  
  4. 4}  
  5. 5console.log(name); // logs 'Hammad' 

JS 的初學(xué)者經(jīng)常需要花點(diǎn)時(shí)間才能習(xí)慣變量提升,而如果不理解這種特有行為,就可能導(dǎo)致 bug 。正因?yàn)槿绱耍?ES6 引入了塊級(jí)作用域,讓變量的生命周期更加可控。

3.塊級(jí)作用域

塊級(jí)作用域可通過新增命令let和const聲明,所聲明的變量在指定塊的作用域外無法被訪問。塊級(jí)作用域在如下情況被創(chuàng)建:

  1.  在一個(gè)函數(shù)內(nèi)部
  2.  在一個(gè)代碼塊(由一對(duì)花括號(hào)包裹)內(nèi)部

let 聲明的語法與 var 的語法一致。你基本上可以用 let 來代替 var 進(jìn)行變量聲明,但會(huì)將變量的作用域限制在當(dāng)前代碼塊中。塊級(jí)作用域有以下幾個(gè)特點(diǎn):

  •  聲明變量不會(huì)提升到代碼塊頂部

let/const 聲明并不會(huì)被提升到當(dāng)前代碼塊的頂部,因此你需要手動(dòng)將 let/const 聲明放置到頂部,以便讓變量在整個(gè)代碼塊內(nèi)部可用。 

  1. 1function getValue(condition) {  
  2. 2if (condition) {  
  3. 3let value = "blue" 
  4. 4return value;  
  5. 5} else {  
  6. 6// value 在此處不可用  
  7. 7return null;  
  8. 8}  
  9. 9// value 在此處不可用  
  10. 0} 
  •  禁止重復(fù)聲明

如果一個(gè)標(biāo)識(shí)符已經(jīng)在代碼塊內(nèi)部被定義,那么在此代碼塊內(nèi)使用同一個(gè)標(biāo)識(shí)符進(jìn)行 let 聲明就會(huì)導(dǎo)致拋出錯(cuò)誤。例如: 

  1. 1var count = 30 
  2. 2let count = 40; // Uncaught SyntaxError: Identifier 'count' has already been declared 

在本例中, count 變量被聲明了兩次:一次使用 var ,另一次使用 let 。因?yàn)?let 不能在同一作用域內(nèi)重復(fù)聲明一個(gè)已有標(biāo)識(shí)符,此處的 let 聲明就會(huì)拋出錯(cuò)誤。但如果在嵌套的作用域內(nèi)使用 let 聲明一個(gè)同名的新變量,則不會(huì)拋出錯(cuò)誤。 

  1. 1var count = 30 
  2. 2// 不會(huì)拋出錯(cuò)誤  
  3. 3if (condition) {  
  4. 4let count = 40 
  5. 5// 其他代碼  
  6. 6} 
  •  循環(huán)中的綁定塊作用域的妙用

開發(fā)者可能最希望實(shí)現(xiàn)for循環(huán)的塊級(jí)作用域了,因?yàn)榭梢园崖暶鞯挠?jì)數(shù)器變量限制在循環(huán)內(nèi),例如,以下代碼在 JS 經(jīng)常見到: 

  1. 1<button>測(cè)試1</button>  
  2.  2<button>測(cè)試2</button>  
  3.  3<button>測(cè)試3</button>  
  4.  4<script type="text/javascript">  
  5.  5   var btns = document.getElementsByTagName('button')  
  6.  6    for (var i = 0; i < btns.length; i++) {  
  7.  7      btns[i].onclick = function () {  
  8.  8        console.log('第' + (i + 1) + '個(gè)')  
  9.  9      }  
  10. 10    } 
  11. 11</script>   

我們要實(shí)現(xiàn)這樣的一個(gè)需求: 點(diǎn)擊某個(gè)按鈕, 提示"點(diǎn)擊的是第n個(gè)按鈕",此處我們先不考慮事件代理,萬萬沒想到,點(diǎn)擊任意一個(gè)按鈕,后臺(tái)都是彈出“第四個(gè)”,這是因?yàn)閕是全局變量,執(zhí)行到點(diǎn)擊事件時(shí),此時(shí)i的值為3。那該如何修改,最簡(jiǎn)單的是用let聲明i 

  1. 1 for (let i = 0; i < btns.length; i++) {  
  2. 2    btns[i].onclick = function () {  
  3. 3      console.log('第' + (i + 1) + '個(gè)')  
  4. 4    }  
  5. 5  } 

作用域鏈

1.什么是自由變量

首先認(rèn)識(shí)一下什么叫做 自由變量 。如下代碼中,console.log(a)要得到a變量,但是在當(dāng)前的作用域中沒有定義a(可對(duì)比一下b)。當(dāng)前作用域沒有定義的變量,這成為 自由變量 。自由變量的值如何得到 —— 向父級(jí)作用域?qū)ふ遥ㄗ⒁猓哼@種說法并不嚴(yán)謹(jǐn),下文會(huì)重點(diǎn)解釋)。 

  1. 1var a = 100  
  2. 2function fn() {  
  3. 3    var b = 200  
  4. 4    console.log(a) // 這里的a在這里就是一個(gè)自由變量  
  5. 5    console.log(b)  
  6. 6}  
  7. 7fn() 

2.什么是作用域鏈

如果父級(jí)也沒呢?再一層一層向上尋找,直到找到全局作用域還是沒找到,就宣布放棄。這種一層一層的關(guān)系,就是 作用域鏈 。 

  1.  1var a = 100  
  2.  2function F1() {  
  3.  3    var b = 200  
  4.  4    function F2() {  
  5.  5        var c = 300  
  6.  6        console.log(a) // 自由變量,順作用域鏈向父作用域找  
  7.  7        console.log(b) // 自由變量,順作用域鏈向父作用域找  
  8.  8        console.log(c) // 本作用域的變量  
  9.  9    }  
  10. 10    F2()  
  11. 11}  
  12. 12F1() 

3.關(guān)于自由變量的取值

關(guān)于自由變量的值,上文提到要到父作用域中取,其實(shí)有時(shí)候這種解釋會(huì)產(chǎn)生歧義。 

  1.  1var x = 10  
  2.  2function fn() {  
  3.  3  console.log(x)  
  4.  4}  
  5.  5function show(f) {  
  6.  6  var x = 20  
  7.  7  (function() {  
  8.  8    f() //10,而不是20  
  9.  9  })()  
  10. 10}  
  11. 11show(fn) 

在fn函數(shù)中,取自由變量x的值時(shí),要到哪個(gè)作用域中取?——要到創(chuàng)建fn函數(shù)的那個(gè)作用域中取,無論fn函數(shù)將在哪里調(diào)用。

所以,不要在用以上說法了。相比而言,用這句話描述會(huì)更加貼切:要到創(chuàng)建這個(gè)函數(shù)的那個(gè)域”。 作用域中取值,這里強(qiáng)調(diào)的是“創(chuàng)建”,而不是“調(diào)用”,切記切記——其實(shí)這就是所謂的"靜態(tài)作用域" 

  1.  1var a = 10  
  2.  2function fn() {  
  3.  3  var b = 20  
  4.  4  function bar() {  
  5.  5    console.log(a + b) //30  
  6.  6  }  
  7.  7  return bar  
  8.  8}  
  9.  9var x = fn(),  
  10. 10  b = 200  
  11. 11x() //bar() 

fn()返回的是bar函數(shù),賦值給x。執(zhí)行x(),即執(zhí)行bar函數(shù)代碼。取b的值時(shí),直接在fn作用域取出。取a的值時(shí),試圖在fn作用域取,但是取不到,只能轉(zhuǎn)向創(chuàng)建fn的那個(gè)作用域中去查找,結(jié)果找到了,所以最后的結(jié)果是30

作用域與執(zhí)行上下文

許多開發(fā)人員經(jīng)常混淆作用域和執(zhí)行上下文的概念,誤認(rèn)為它們是相同的概念,但事實(shí)并非如此。

我們知道JavaScript屬于解釋型語言,JavaScript的執(zhí)行分為:解釋和執(zhí)行兩個(gè)階段,這兩個(gè)階段所做的事并不一樣:

解釋階段:

  •  詞法分析
  •  語法分析
  •  作用域規(guī)則確定

執(zhí)行階段:

  •  創(chuàng)建執(zhí)行上下文
  •  執(zhí)行函數(shù)代碼
  •  垃圾回收

JavaScript解釋階段便會(huì)確定作用域規(guī)則,因此作用域在函數(shù)定義時(shí)就已經(jīng)確定了,而不是在函數(shù)調(diào)用時(shí)確定,但是執(zhí)行上下文是函數(shù)執(zhí)行之前創(chuàng)建的。執(zhí)行上下文最明顯的就是this的指向是執(zhí)行時(shí)確定的。而作用域訪問的變量是編寫代碼的結(jié)構(gòu)確定的。

作用域和執(zhí)行上下文之間最大的區(qū)別是: 執(zhí)行上下文在運(yùn)行時(shí)確定,隨時(shí)可能改變;作用域在定義時(shí)就確定,并且不會(huì)改變。

一個(gè)作用域下可能包含若干個(gè)上下文環(huán)境。有可能從來沒有過上下文環(huán)境(函數(shù)從來就沒有被調(diào)用過);有可能有過,現(xiàn)在函數(shù)被調(diào)用完畢后,上下文環(huán)境被銷毀了;有可能同時(shí)存在一個(gè)或多個(gè)(閉包)。同一個(gè)作用域下,不同的調(diào)用會(huì)產(chǎn)生不同的執(zhí)行上下文環(huán)境,繼而產(chǎn)生不同的變量的值。 

 

責(zé)任編輯:龐桂玉 來源: 前端大全
相關(guān)推薦

2011-09-06 09:56:24

JavaScript

2019-03-13 08:00:00

JavaScript作用域前端

2021-06-02 07:02:42

js作用域函數(shù)

2015-08-18 13:42:42

js作用域鏈變量

2021-03-17 08:39:24

作用域作用域鏈JavaScript

2021-03-16 22:25:06

作用域鏈作用域JavaScript

2017-09-14 13:55:57

JavaScript

2011-05-12 18:26:08

Javascript作用域

2009-12-09 14:04:45

PHP include

2010-09-25 16:10:09

添加DHCP作用域

2020-11-19 07:49:24

JS變量作用域

2021-06-10 18:11:02

Cors跨域Web開發(fā)Cors

2010-08-25 15:19:20

DHCP作用域

2010-09-29 15:02:23

DHCP作用域

2011-04-18 09:31:35

JavaScript

2020-08-25 10:02:09

AndroidHilt作用域

2025-01-09 11:18:40

Python作用域編程

2010-01-07 16:16:03

VB.NET變量作用域

2013-06-14 09:27:51

Express.jsJavaScript

2022-05-10 08:47:00

JMeter作用域執(zhí)行順序
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

四虎永久在线精品免费网址| 天天天天天天天天操| 婷婷综合六月| 国产精品午夜免费| 亚洲最大av网站| 日本一级片免费看| 日韩免费特黄一二三区| 欧美成人精品福利| 无码人妻丰满熟妇区毛片| 日本美女在线中文版| 国产成人av影院| 国产精品18久久久久久首页狼| 欧美性受xxxx黑人| 激情视频极品美女日韩| 欧美三级电影精品| 久激情内射婷内射蜜桃| 在线免费av电影| www.亚洲国产| 91九色在线视频| 日本在线播放视频| 欧美激情日韩| 自拍偷拍亚洲欧美| 91av在线免费| 亚洲精品观看| 欧美久久久久中文字幕| 2018国产在线| 99福利在线| 国产精品三级av在线播放| 国产一区二区高清不卡| 国产模特av私拍大尺度| 日韩电影免费一区| 国内外成人免费激情在线视频| frxxee中国xxx麻豆hd| 竹菊久久久久久久| 欧美成人一区二区| 99九九99九九九99九他书对| 日韩性xxx| 婷婷一区二区三区| 成人午夜免费在线视频| 欧美jizzhd69巨大| 亚洲国产成人在线| 日本一区二区不卡高清更新| 亚洲三级中文字幕| 成人app下载| av资源一区二区| www.av网站| 国产精品一卡二| 亚洲qvod图片区电影| 亚洲专区第一页| 奇米影视在线99精品| 日本sm极度另类视频| 国产精品久久久久久99| 亚洲高清电影| 韩国v欧美v日本v亚洲| 国产在线观看免费av| 欧美日本久久| 海角国产乱辈乱精品视频| 伊人国产在线观看| 亚洲美女一区| 奇米4444一区二区三区| 天天操夜夜操视频| 久久蜜桃精品| 国产精品人成电影| 亚洲图片中文字幕| 国产原创一区二区| 99免费在线视频观看| 亚洲精品久久久久久久久久| 成人精品视频一区| 久久精品一二三区| 精品乱码一区二区三四区视频| 国产午夜久久久久| 亚洲免费在线精品一区| 国产一区久久精品| 亚洲一区二区三区四区在线观看 | 精品免费视频| 中文字幕亚洲欧美| 四虎免费在线视频| 99国产精品99久久久久久粉嫩| 欧美综合在线第二页| 99re这里只有精品在线| 精品亚洲免费视频| 国产精品99久久久久久久| 日韩一二三四| 国产精品初高中害羞小美女文| 日本xxxxx18| 激情黄产视频在线免费观看| 色婷婷av一区| 四虎国产精品永久免费观看视频| 国产精品tv| 亚洲男女性事视频| 欧美性生交大片| 亚洲国产日本| 91精品久久久久久久久久| 亚洲精品一区二区三区蜜桃| 久久先锋影音av鲁色资源网| 亚洲五月六月| 色在线视频观看| 欧美日韩电影一区| 国产黑丝一区二区| 91亚洲人成网污www| 亚州欧美日韩中文视频| 一二三区在线播放| 91在线视频播放地址| 综合久久国产| 成人在线爆射| 亚洲国语精品自产拍在线观看| 1024在线看片| 午夜影院日韩| yellow视频在线观看一区二区 | 久久免费国产精品| 国产美女视频免费| 吞精囗交69激情欧美| 日韩欧美黄色影院| 精品伦精品一区二区三区视频密桃| 在线精品亚洲| 91精品久久香蕉国产线看观看| 黄色美女网站在线观看| 亚洲综合免费观看高清在线观看| 亚洲最大综合网| 亚洲美女15p| 久久久久久亚洲精品| 国产精品国产av| 国产精品情趣视频| 欧美日韩在线中文| swag国产精品一区二区| 久久综合久久88| 一级黄在线观看| 亚洲国产精品成人综合色在线婷婷| www.99热这里只有精品| 911精品国产| 美女av一区二区三区| 在线观看亚洲国产| 欧美激情在线观看视频免费| 亚洲 高清 成人 动漫| 精品一区二区男人吃奶| 欧美精品电影免费在线观看| 国产麻豆91视频| 亚洲欧洲av在线| 午夜啪啪小视频| 91一区二区三区四区| 日本高清久久天堂| 欧美日韩在线精品一区二区三区激情综| 亚洲一区欧美一区| 欧美69精品久久久久久不卡 | 国产乱子伦农村叉叉叉| 成人在线视频你懂的| 欧美另类xxx| 亚洲精品久久久蜜桃动漫| 亚洲综合无码一区二区| 久久久久亚洲av无码专区首jn| 综合久久婷婷| 成人区精品一区二区| 成人免费一区二区三区牛牛| 亚洲第一精品久久忘忧草社区| 国产精品日日夜夜| 99re这里只有精品视频首页| 激情深爱综合网| 亚洲视频分类| 国产精品久久久久久久久久尿| 国产精品一二三区视频| 欧美日韩在线播| 老熟妻内射精品一区| 国产黄人亚洲片| 精品视频在线观看一区| 网红女主播少妇精品视频| 国产成人免费91av在线| 免费黄色网址在线观看| 日韩欧美第一区| 在线观看国产亚洲| 国产色91在线| 日韩视频在线观看一区二区三区| 亚洲欧美在线专区| 国产日韩在线一区二区三区| 日韩av一卡| 色偷偷噜噜噜亚洲男人| 91成人在线免费| 亚洲午夜一二三区视频| 精品人妻一区二区三区视频| 麻豆精品一区二区| 国产一区二区三区小说| 国产一区二区三区探花| 成人国产精品一区| cao在线视频| 中文字幕日韩精品有码视频| 国产区精品在线| 午夜精品爽啪视频| 欧美激情 一区| 国产成人在线看| 91看片就是不一样| 综合激情网站| 欧美一卡2卡3卡4卡无卡免费观看水多多| 人人玩人人添人人澡欧美| 欧美高清电影在线看| 男女视频在线观看免费| 欧美一卡在线观看| 国产一区免费看| 亚洲在线视频网站| 国产精品20p| 成a人片亚洲日本久久| 成人亚洲精品777777大片| 亚洲午夜一区| 一本一生久久a久久精品综合蜜 | 972aa.com艺术欧美| 青青草久久伊人| 性色一区二区| 欧美国产视频一区| 久久精品国产亚洲夜色av网站 | 青青青草网站免费视频在线观看| 91精品国产色综合久久ai换脸| 中文字字幕在线中文| 亚洲精品日产精品乱码不卡| 天天躁夜夜躁狠狠是什么心态 | 在线观看国产精品一区| 国产suv一区二区三区88区| av网站在线不卡| 亚洲一区日韩| 国产极品在线视频| 中文字幕亚洲精品乱码| 青青草原亚洲| 天天躁日日躁成人字幕aⅴ| 97碰碰视频| 四虎成人精品一区二区免费网站| 国产suv精品一区二区| 18video性欧美19sex高清| 久久国产精品久久久| 成人高清免费观看mv| 亚洲美女喷白浆| 刘玥91精选国产在线观看| 欧美一区二区三区思思人 | 欧美成人三级电影在线| 国产美女主播在线观看| 欧美精品一二三四| 又污又黄的网站| 欧美亚洲日本国产| 免费观看日批视频| 一本一本久久a久久精品综合麻豆| 欧美亚洲天堂网| 亚洲国产欧美日韩另类综合 | 欧美自拍偷拍网| 国产天堂亚洲国产碰碰| 久久久久久九九九九九| 91在线你懂得| 成人精品999| 国产亚洲精品7777| 日韩免费成人av| 日本一二三不卡| 国产亚洲精品久久久久久| 精品在线观看一区| 国产精品久久久久久亚洲毛片 | 国产精品伦理在线| 懂色av粉嫩av浪潮av| 日本一区二区免费在线| 国产在线综合视频| 国产精品久久久久久久久搜平片| 亚洲色图 激情小说| 国产精品视频一二| 无码人妻精品中文字幕| 亚洲乱码一区二区三区在线观看| 91插插插插插插| 一个色综合av| 日本网站免费观看| 欧美三级免费观看| 精人妻无码一区二区三区| 欧美午夜视频网站| 国产男男gay体育生白袜| 欧美videos中文字幕| 少妇高潮一区二区三区99小说 | 成人信息集中地欧美| www一区二区三区| wwwxx欧美| 亚洲精品亚洲人成在线| 色综合久久av| 女同性一区二区三区人了人一| 福利视频一区二区三区四区| 免费在线播放第一区高清av| 污污网站免费观看| 国产电影一区二区三区| 亚洲一区二区乱码| 中文字幕不卡一区| 青青操国产视频| 欧美午夜片在线免费观看| 在线免费观看视频网站| 精品国一区二区三区| 国产综合视频一区二区三区免费| 日韩中文字幕国产| 嗯啊主人调教在线播放视频 | 中文天堂在线资源| 欧美一区二区网站| 欧美zzoo| 欧美激情喷水视频| 四虎4545www精品视频| 91传媒视频免费| 欧美日韩123| 日本天堂免费a| 日韩高清中文字幕一区| 中文字幕avav| 国产欧美一区二区三区沐欲 | 欧美成年黄网站色视频| 97在线观看免费| 成人国产精品久久| 欧美日韩一区在线视频| 欧美午夜一区二区福利视频| 韩国日本美国免费毛片| 成人综合在线视频| 精品在线观看一区| 欧美视频在线观看免费网址| 999免费视频| 中文字幕欧美在线| 涩涩视频网站在线观看| 999国产在线| 久久国产中文字幕| 国产日产欧美视频| 国产xxx精品视频大全| fc2ppv在线播放| 色综合天天综合网国产成人综合天 | 在线播放亚洲一区| 国产一二三在线观看| 97精品视频在线观看| 视频欧美一区| 日本福利视频导航| 热久久国产精品| 泷泽萝拉在线播放| 亚洲第一在线综合网站| 国产成人a人亚洲精品无码| 在线播放日韩专区| 日韩成人影音| 欧美精品七区| 国产亚洲在线观看| 五月天激情小说| 亚洲国产中文字幕| 精品人妻少妇嫩草av无码专区| 日韩在线中文视频| 成人全视频在线观看在线播放高清 | 国产又大又黄的视频| 在线精品91av| 精品免费av一区二区三区| 欧美一区二区福利| 亚洲免费综合| 亚洲成人网在线播放| 欧美性精品220| 免费在线稳定资源站| 欧美伊久线香蕉线新在线| 久久夜色电影| 免费无遮挡无码永久视频| 99久久久精品| 中文在线第一页| 亚洲小视频在线观看| yy6080久久伦理一区二区| 日本在线观看不卡| 日韩avvvv在线播放| 91成人精品一区二区| 欧美在线观看一区二区| 99中文字幕一区| 91久久国产综合久久91精品网站| 99视频精品全国免费| 欧美成人手机在线视频| 一区二区三区中文字幕精品精品| 一级特黄a大片免费| 视频一区中文字幕精品| 日韩欧美国产二区| 日本免费在线视频不卡一不卡二| 中文字幕有码在线播放| 欧美少妇xxx| 成人免费网址| 国产精品免费一区二区三区观看 | 91欧美一区二区三区| 亚洲精品久久7777| 黄色美女一级片| 欧洲精品在线视频| 日韩欧美视频在线播放| 无人码人妻一区二区三区免费| 亚洲国产精品人人做人人爽| 男生女生差差差的视频在线观看| 国产精自产拍久久久久久蜜| 欧美成人一品| 亚洲狠狠婷婷综合久久久久图片| 在线观看不卡一区| 福利视频在线| 精品日产一区2区三区黄免费 | 在线精品在线| 中文字幕av久久爽一区| 91精品国产色综合久久ai换脸| 国产伦理精品| 一区二区三区免费看| 成人午夜视频免费看| 国产精品乱码一区二区视频| 久久久91精品国产| 日韩中出av| 五月天开心婷婷| 欧美午夜激情小视频| 免费a级毛片在线播放| 九色综合婷婷综合| 久久99精品久久久久| 国产成人无码精品久久久久| 中文字幕一区二区三区电影| 大型av综合网站| 色啦啦av综合| 欧美日韩国产在线看| a级网站在线播放| 日韩在线观看电影完整版高清免费|