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

12個提高JavaScript技能的概念

開發 前端
JavaScript 是一種復雜的語言。如果是你是高級或者初級 JavaScript 開發人員,了解它的基本概念非常重要。本文介紹 JavaScript 至關重要的12個概念,但絕對不是說 JavaScript 開發人員只需要知道這些就可以了。

JavaScript 是一種復雜的語言。如果是你是高級或者初級 JavaScript 開發人員,了解它的基本概念非常重要。本文介紹 JavaScript 至關重要的12個概念,但絕對不是說 JavaScript 開發人員只需要知道這些就可以了。

1.變量賦值 (值 vs 引用)

理解 JavaScript 如何給變量賦值可以幫助我們減少一些不必要的 bug。如果你不理解這一點,可能很容易地編寫被無意中更改值的代碼。

JavaScript 總是按照值來給變量賦值。 這一部分非常重要:當指定的值是 JavaScript 的五種基本類型之一(即 Boolean,null,undefined,String 和 Number)時,將分配實際值。 但是,當指定的值是 Array,Function或Object時,將分配對內存中對象的引用給變量。

在以下代碼段中,使用 var1 對 var2 進行賦值。 由于var1是基本類型(String),因此 var2 的值等于 var1 的 String 值,并且可以認為此時與var1完全不同。 因此,重新賦值var2對var1沒有影響。

12個提高 JavaScript 技能的概念

 

接著,與對象賦值進行比較。

12個提高 JavaScript 技能的概念

 

如果你期望它會像原始類型賦值那樣,很可能會出問題!如果你創建了一個無意中會改變對象的函數,就會出現一些非預期的行為。

2.閉包

閉包是一個重要的JavaScript模式,可以私有訪問變量。在本例中,createGreeter返回一個匿名函數,這個函數可以訪問參數 greeting(在這里是“Hello”)。在后續的調用中,sayHello 將有權訪問這個 greeting!

12個提高 JavaScript 技能的概念

 

在更真實的場景中,你可以設想一個初始函數apiConnect(apiKey),它返回一些使用API key的方法。在這種情況下,apiKey 只需要提供一次即可。

12個提高 JavaScript 技能的概念

 

3.解構

JavaScript 參數解構可以從對象中干中提取所需屬性的常用方法。

12個提高 JavaScript 技能的概念

 

如果要以其他名稱提取屬性,可以使用如下方式:

12個提高 JavaScript 技能的概念

 

解構經常也用于直接用于提取傳給函數的參數。如果你熟悉 React,可能已經見過這個:

12個提高 JavaScript 技能的概念

 

4. 展開運算

ES6的一個常用之一的特性就是展開(...)運算符了,在下面的例子中,Math.max 不能應用于 arr 數組,因為它不將數組作為參數,但它可以將各個元素作為參數傳入。展開運算符...可用于提取數組的各個元素。

5. 剩余參數

剩余參數語法和展開語法看起來的一樣的,不同的是展開語法是為了結構數組和對象;而剩余參數和展開運算符是相反的,剩余參數收集多個元素合成一個數組。

  1. function myFunc(...args) { 
  2.   console.log(args[0] + args[1]); 
  3. myFunc(1, 2, 3, 4); 
  4. // 3 

rest parametersarguments 的區別

  1. arguments 是偽數組,包含所有的實參
  2. 剩余參數 是標準的數組,可以使用數組的方法

6. 數組方法

JavaScript 數組方法通常可以提供令人難以置信的、優雅的方法來執行所需的數據轉換。作為StackOverflow 的貢獻者,我經常看到關于如何以某種方式操縱對象數組的問題,這往往也是數組方法的完美用例。

map、filter、reduce

JavaScript 數組方法map、filter和reduce容易混淆,這些都是轉換數組或返回聚合值的有用方法。

map:返回一個數組,其中每個元素都使用指定函數進行過轉換。

  1. const arr = [1, 2, 3, 4, 5, 6]; 
  2. const mapped = arr.map(el => el + 20); 
  3. console.log(mapped); 
  4. // [21, 22, 23, 24, 25, 26] 

filter:返回一個數組,只有當指定函數返回 true 時,相應的元素才會被包含在這個數組中。

  1. const arr = [1, 2, 3, 4, 5, 6]; 
  2. const filtered = arr.filter(el => el === 2 || el === 4); 
  3. console.log(filtered); 
  4. // [2, 4] 

reduce:按函數中指定的值累加

  1. const arr = [1, 2, 3, 4, 5, 6]; 
  2. const reduced = arr.reduce((total, current) => total + current); 
  3. console.log(reduced); 
  4. // 21 

find, findIndex, indexOf

find:返回與指定條件匹配的第一個實例,如果查到不會繼續查找其他匹配的實例。

  1. const arr = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]; 
  2. const found = arr.find(el => el > 5); 
  3. console.log(found); 
  4. // 6 

再次注意,雖然5之后的所有元素都滿足條件,但是只返回第一個匹配的元素。當你發現匹配項時,通常會中斷for循環,在這種情況下,這實際上非常有用。

findIndex:這與find幾乎完全相同,但不是返回第一個匹配元素,而是返回第一個匹配元素的索引。

  1. const arr = ['Nick''Frank''Joe''Frank']; 
  2. const foundIndex = arr.findIndex(el => el === 'Frank'); 
  3. console.log(foundIndex); 
  4. // 1 

indexOf:與findIndex幾乎完全相同,但它不是將函數作為參數,而是采用一個簡單的值。 當w你需要更簡單的邏輯并且不需要使用函數來檢查是否存在匹配時,可以使用此方法。

  1. const arr = ['Nick''Frank''Joe''Frank']; 
  2. const foundIndex = arr.indexOf('Frank'); 
  3. console.log(foundIndex); 
  4. // 1 

push, pop, shift, unshift

push:這是一個相對簡單的方法,它將一個項添加到數組的末尾。它就地修改數組,函數本身會返回添加到數組中的項。

  1. let arr = [1, 2, 3, 4]; 
  2. const pushed = arr.push(5); 
  3. console.log(arr); 
  4. // [1, 2, 3, 4, 5] 
  5. console.log(pushed); 
  6. // 5 

pop:這將從數組中刪除最后一項。同樣,它在適當的位置修改數組,函數本身返回從數組中刪除的項。

  1. let arr = [1, 2, 3, 4]; 
  2. const popped = arr.pop(); 
  3. console.log(arr); 
  4. // [1, 2, 3] 
  5. console.log(popped); 
  6. // 4 

shift:從數組中刪除第一項。同樣,它在適當的位置修改數組。函數本身返回從數組中刪除的項。

  1. let arr = [1, 2, 3, 4]; 
  2. const shifted = arr.shift(); 
  3. console.log(arr); 
  4. // [2, 3, 4] 
  5. console.log(shifted); 
  6. // 1 

unshift:將一個或多個元素添加到數組的開頭。同樣,它在適當的位置修改數組。與許多其他方法不同,函數本身返回數組的新長度。

  1. let arr = [1, 2, 3, 4]; 
  2. const unshifted = arr.unshift(5, 6, 7); 
  3. console.log(arr); 
  4. // [5, 6, 7, 1, 2, 3, 4] 
  5. console.log(unshifted); 
  6. // 7 

splice, slice

**splice:**通過刪除或替換現有元素和/或添加新元素來更改數組的內容,此方法會修改了數組本身。

下面的代碼示例的意思是:在數組的位置 1 上刪除 0 個元素,并插入 b。

  1. let arr = ['a''c''d''e']; 
  2. arr.splice(1, 0, 'b'

slice:從指定的起始位置和指定的結束位置之前返回數組的淺拷貝。 如果未指定結束位置,則返回數組的其余部分。 重要的是,此方法不會修改數組,而是返回所需的子集。

  1. let arr = ['a''b''c''d''e']; 
  2. const sliced = arr.slice(2, 4); 
  3.  
  4. console.log(sliced); 
  5. // ['c''d'
  6. console.log(arr); 
  7. // ['a''b''c''d''e'

sort

**sort:**根據提供的函數對數組進行排序。這個方法就地修改數組。如果函數返回負數或 0,則順序保持不變。如果返回正數,則交換元素順序。

  1. let arr = [1, 7, 3, -1, 5, 7, 2]; 
  2. const sorter = (firstEl, secondEl) => firstEl - secondEl; 
  3. arr.sort(sorter); 
  4.  
  5. console.log(arr); 
  6. // [-1, 1, 2, 3, 5, 7, 7] 

7. Generators(生成器)

生成器是一種特殊的行為,實際上是一種設計模式,我們通過調用**next()方法來遍歷一組有序的值。想象一下,例如使用遍歷器對數組[1,2,3,4,5]進行遍歷。第一次調用next()方法返回1,第二次調用next()方法返回2,以此類推。當數組中的所有值都返回后,調用next()**方法將返回null或false或其它可能的值用來表示數組中的所有元素都已遍歷完畢。

12個提高 JavaScript 技能的概念

 

使用生成器生成無限個值:

12個提高 JavaScript 技能的概念

 

8.恒等運算符(===)與相等運算符(==)

大家一定要知道JavaScript中的恒等運算符(===)和相等運算符(==)之間的區別! ==運算符在比較值之前會進行類型轉換,而===運算符在比較之前不會進行任何類型轉換。

  1. console.log(0 == '0'); 
  2. // true 
  3. console.log(0 === '0'); 
  4. // false 

9. 對象比較

我看到 JavaScript新手所犯的錯誤是直接比較對象。 變量指向內存中對象的引用,而不是對象本身! 實際比較它們的一種方法是將對象轉換為 JSON 字符串。 這有一個缺點:對象屬性順序不能保證! 比較對象的一種更安全的方法是引入專門進行深度對象比較的庫(例如,lodash的isEqual)。

下面的對象看起來是相等的,但實際上它們指向不同的引用。

  1. const joe1 = { name'Joe' }; 
  2. const joe2 = { name'Joe' }; 
  3. console.log(joe1 === joe2); 
  4. // false 

相反,下面的計算結果為true,因為一個對象被設置為與另一個對象相等,因此指向相同的引用(內存中只有一個對象)。

  1. const joe1 = { name'Joe' }; 
  2. const joe2 = joe1; 
  3. console.log(joe1 === joe2); 
  4. // true 

相反,以下計算結果為true,因為一個對象設置為等于另一個對象,因此指向相同的引用(內存中只有一個對象)。

  1. const joe1 = { name'Joe' }; 
  2. const joe2 = joe1; 
  3. console.log(joe1 === joe2); 
  4. // true 

10. 回調函數

很多人都被 JavaScript 回調函數嚇倒了! 他們很簡單,舉個例子。 console.log 函數作為回調傳遞給myFunc。 它在setTimeout完成時執行。

  1. function myFunc(text, callback) { 
  2.   setTimeout(function() { 
  3.     callback(text); 
  4.   }, 2000); 
  5. myFunc('Hello world!', console.log); 
  6. // 'Hello world!' 

11. Promises

一旦你理解了 JavaScript 回調,很快就會發現自己陷入了“回調地獄”中。這個時候可以使用 promise,將異步邏輯包裝在 promise 中,成功時 resolve 或在失敗時reject 使用“then”來處理成功的情況,使用catch來處理異常。

12個提高 JavaScript 技能的概念

 

12. Async/Await

在掌握了 promise 的用法后,你可能也會喜歡 async await,它只是一種基于 promise 的“語法糖”。在下面的示例中,我們創建了一個 async 函數,并 await greeter promise。

12個提高 JavaScript 技能的概念 

 

責任編輯:龐桂玉 來源: 前端小智
相關推薦

2020-03-05 08:58:42

JavaScript語言開發

2022-08-20 19:12:22

編程竅門

2015-08-04 10:51:26

vim效率技巧

2011-09-05 14:53:57

JavaScript

2022-09-05 14:17:48

Javascript技巧

2015-01-14 10:26:30

JavaScript編程技巧

2020-08-04 08:30:18

JS數組技巧

2014-02-14 09:16:51

JavaScript工具

2018-08-07 09:15:49

2024-06-11 00:09:00

JavaScript模式變量

2016-05-10 10:16:13

JavaScript技巧

2023-11-22 11:30:03

首席信息官IT管理

2023-07-03 10:46:20

CIOIT領導者

2021-06-17 07:45:35

Javascript 技巧效率

2020-11-12 15:57:26

機器學習AI人工智能

2020-11-06 12:56:59

人工智能機器學習技術

2020-09-28 18:19:15

awkLinux

2022-12-26 08:25:16

JavaScriptweb瀏覽器

2020-04-16 09:54:39

JavaScript前端技術

2020-05-13 16:54:05

JavaScript開發代碼
點贊
收藏

51CTO技術棧公眾號

国产精品久久97| 台湾佬综合网| 国产精品黑丝在线播放| 一区二区在线观看视频| 国产91精品网站| 色哟哟网站在线观看| 五月天综合激情网| 青草伊人久久| 国产精品久久久久久久久免费丝袜 | 日本精品www| 国产精品视频久久久久久| 日本午夜精品| 亚洲午夜一区二区三区| 91视频8mav| 永久免费看片视频教学| 美女写真久久影院| 久久人人爽人人爽| 欧美日韩aaaa| 波多野结衣免费观看| 中文日本在线观看| 九九久久婷婷| 欧美日韩在线看| 精品无人区一区二区三区| 久久久久99精品| 超碰地址久久| 亚洲一区二区在线视频| 欧美三级电影在线播放| 草莓视频18免费观看| 开心激情综合| 午夜精品一区二区三区免费视频 | 欧美色图色综合| 亚洲国产福利视频| 欧美fxxxxxx另类| 日韩欧美成人激情| 99在线免费视频观看| 亚洲va天堂va欧美ⅴa在线| 日韩福利视频网| 一个色综合导航| 性chinese极品按摩| 色哟哟免费在线观看| 麻豆精品国产传媒mv男同| 中文字幕欧美精品日韩中文字幕| 在线免费视频a| 黄色网页在线免费看| 国产一区视频在线看| 久久99国产精品自在自在app| 精品亚洲aⅴ无码一区二区三区| 成人在线观看免费播放| 国产精品久久久久四虎| 91在线观看免费高清| 中文字幕在线观看国产| 亚洲电影影音先锋| 精品国产免费久久| 欧美日韩中文在线视频| bl在线肉h视频大尺度| 91亚洲精品久久久蜜桃网站| 国产a∨精品一区二区三区不卡| 久久精品国产亚洲av香蕉| 欧美.日韩.国产.一区.二区| 精品国产一区二区三区久久狼5月| 特黄特黄一级片| 日本一区二区三区中文字幕| 亚洲综合网站在线观看| 国产女主播一区二区三区| 色屁屁影院www国产高清麻豆| 日韩欧美国产精品综合嫩v| 日韩午夜小视频| 久久国产色av免费观看| 成人福利网站| 久久久一区二区三区捆绑**| 91久久精品国产91久久性色| 一本色道久久综合精品婷婷 | www.99久久热国产日韩欧美.com| 波多野结衣家庭教师在线观看 | 日韩av在线发布| 亚洲丝袜在线视频| 四虎成人在线播放| 国产网站在线| 国产精品国产三级国产a| 伊人久久青草| 欧美在线一卡| 粉嫩一区二区三区在线看| 国产999在线观看| 一级一级黄色片| 亚洲精选一区| 欧美精品亚州精品| 亚洲一二三四视频| 国产精品久久久久久久免费观看| 久操成人在线视频| 国产一级精品视频| 男人的j进女人的j一区| 91av视频在线免费观看| 波多野结衣爱爱视频| 夜夜春成人影院| 亚洲精品一区二区三区影院| 丰满圆润老女人hd| 精品自拍偷拍| 亚洲一二在线观看| 久久午夜夜伦鲁鲁片| 韩国一区二区三区视频| 欧美日韩免费在线视频| 人妻少妇被粗大爽9797pw| 国产精品麻豆成人av电影艾秋| 婷婷国产v国产偷v亚洲高清| 国产成人一区二区三区别| 麻豆网站视频在线观看| 国产精品久久久久久久浪潮网站| 欧美在线观看黄| 在线黄色网页| 综合久久综合久久| 在线观看成人一级片| gogo久久| 欧美一区二区视频在线观看| 天堂av手机在线| 无码日韩精品一区二区免费| 精品国产一区av| 中文人妻av久久人妻18| 福利一区二区在线| 在线精品亚洲一区二区| 羞羞影院欧美| 欧美在线短视频| 超碰网在线观看| 91麻豆精品激情在线观看最新 | 欧美另类z0zx974| 色狼人综合干| 九九精品视频在线观看| 一炮成瘾1v1高h| 狠狠色狠狠色综合日日91app| 国产一区香蕉久久| 国产美女主播在线观看| 国产剧情一区二区三区| 999国产在线| 亚洲精品97久久中文字幕无码| 国产欧美一区在线| 婷婷五月色综合| 秋霞成人影院| 欧美在线影院一区二区| 911福利视频| 激情综合婷婷| 久久久精品日本| 国产中文字字幕乱码无限| 久久97超碰色| 国产精品久久7| 黄色网址在线播放| 国产精品久久免费看| 国产情侣av自拍| 在线高清欧美| 亚洲精品在线免费观看视频| 麻豆亚洲av熟女国产一区二| 国产美女一区| 成人激情春色网| 四虎永久在线精品免费网址| 国产欧美一区二区精品婷婷| 欧美极品欧美精品欧美图片| 综合亚洲自拍| 国产精品777| 99精品国产99久久久久久97| 亚洲欧美日韩综合aⅴ视频| 国产无限制自拍| 电影一区二区| 亚洲国产精品福利| 免费黄色国产视频| 日韩午夜在线电影| 成人激情视频在线播放| 色多多视频在线观看| 欧美精品视频www在线观看| 国产免费一区二区三区最新6| blacked蜜桃精品一区| 欧美激情一区二区三区成人 | 99精品热6080yy久久| 国产乱码精品一区二区三区日韩精品| 麻豆免费在线| 欧美精品乱码久久久久久| 欧美a级片免费看| 国产精品一级黄| 国产午夜伦鲁鲁| 日本免费一区二区三区视频| 欧美激情日韩图片| 黄色网址中文字幕| 成人免费高清在线| 日本女人高潮视频| 一区在线影院| 美女福利视频一区| 天堂av网在线| 亚洲第一搞黄网站| 日本成人在线免费观看| 欧美色就是色| 国产成人在线一区二区| 五月婷婷在线观看| 亚洲国产欧美久久| 久久机热这里只有精品| 久久一区二区视频| 午夜免费一级片| 销魂美女一区二区三区视频在线| 69174成人网| 超碰一区二区| 日韩毛片在线看| 国产对白videos麻豆高潮| 国产美女精品一区二区三区| 欧美 日韩 国产在线观看| 成人嘿咻视频免费看| 国产精品青青草| 日韩护士脚交太爽了| 97人人模人人爽人人喊中文字| 国产高清第一页| 亚洲欧美一区二区视频| 国产夫妻性爱视频| 99国产精品私拍| 一区二区三区av在线| 国产成人a视频高清在线观看| 欧美激情国内偷拍| gogogo高清在线观看免费完整版| 在线视频综合导航| 久久免费精彩视频| 成人综合婷婷国产精品久久免费| 国产精品人人妻人人爽人人牛| 国产精品激情| 国产视频一区二区不卡| vam成人资源在线观看| 欧美在线影院在线视频| 国产一级片在线| 亚洲国内精品视频| 精品人妻一区二区三区三区四区 | 日韩不卡一二区| 国内精品久久久久久久影视简单| 国产成人精品一区二区在线| 2019中文字幕在线电影免费| 久久国产精品首页| 91看片在线观看| 国产亚洲xxx| 人人九九精品| 日韩经典中文字幕在线观看| 国产污视频网站| 欧美性猛交xxxxx水多| 韩国女同性做爰三级| 美女在线视频一区| 日韩有码免费视频| 欧美视频不卡| 日本精品一区二区三区不卡无字幕| 欧美一级二级视频| 国产91色在线|| 三上悠亚一区二区| 欧美孕妇性xx| 激情在线小视频| 日韩有码视频在线| 国产黄在线播放| 日韩一区二区免费在线观看| 国产内射老熟女aaaa∵| 欧美午夜视频在线观看| 精品无码m3u8在线观看| 亚洲国产cao| 天天插天天操天天干| 国产日韩影视精品| 久久久久99人妻一区二区三区| 国产精品一区二区在线观看不卡| 免费成人黄色大片| 99在线精品免费视频九九视| 国产精品999视频| 欧美国产偷国产精品三区| 成人免费看片网址| 欧美日韩不卡| 国产精品爽黄69天堂a| 国产精品论坛| 秋霞午夜一区二区| 91成人在线| 成人性生交大片免费看视频直播 | 伊人av成人| 国产精品成人一区二区不卡| 国产一二三四区在线观看| 日韩高清成人在线| 日韩av高清在线播放| 亚洲一二av| 国产日韩欧美黄色| 麻豆精品久久| 韩国成人一区| 欧美日韩国产免费观看视频| 国产福利片一区二区| 欧美精选一区二区三区| 一级黄色免费在线观看| 在线国产欧美| 4444在线观看| 亚洲美女少妇无套啪啪呻吟| 午夜激情福利在线| 国产精一区二区三区| 精品人妻一区二区三区视频| 国产精品久久三| 日本三级片在线观看| 欧美熟乱第一页| 黄片毛片在线看| 欧美一区二区三区男人的天堂| 黄色成人一级片| 中文字幕av一区| free性m.freesex欧美| 国产精品网站大全| 精品嫩草影院| 综合视频免费看| 久久精品首页| 99精品免费在线观看| 国内成人免费视频| 波多野结衣av在线观看| 一区二区三区在线视频观看58| 久久精品无码av| 欧美成人在线直播| avtt在线播放| 欧美亚洲日本黄色| 日韩在线精品强乱中文字幕| 婷婷亚洲婷婷综合色香五月| 亚洲精品婷婷| 精品无码av一区二区三区不卡| 国产女人水真多18毛片18精品视频| 国产精品30p| 欧美一区二区在线播放| 国产高清一区在线观看| 韩国日本不卡在线| 一区二区亚洲视频| 日日噜噜夜夜狠狠久久丁香五月| 日韩高清在线一区| 国产毛片毛片毛片毛片毛片毛片| 亚洲色图.com| 亚洲熟妇无码久久精品| 亚洲色图第一页| 色在线中文字幕| 国内精品**久久毛片app| 欧美在线亚洲| 欧洲美女亚洲激情| 国产精品美女久久久久久 | a级网站在线播放| 国产欧美亚洲精品| 精品视频免费在线观看| 日韩免费毛片视频| 91色在线porny| 欧美人妻一区二区三区| 欧美日韩在线视频首页| 人人妻人人澡人人爽精品日本| 亚洲乱码av中文一区二区| av在线电影网| 国产精品成人一区二区| 欧洲亚洲视频| 人妻熟妇乱又伦精品视频| 成人动漫精品一区二区| 成人免费无遮挡无码黄漫视频| 精品国产福利在线| 天堂网在线资源| 97在线免费观看视频| 韩国女主播一区二区三区| 欧美精品一区三区在线观看| 美女91精品| 国产人妻大战黑人20p| 色婷婷精品大在线视频| 国产欧美久久久| 久久成人国产精品| 日韩pacopacomama| 欧美视频小说| 日韩精品电影在线观看| 久久久国产一级片| 欧美高清精品3d| av毛片在线看| 丁香婷婷久久久综合精品国产| 亚洲福利久久| xxxx日本免费| 亚洲综合清纯丝袜自拍| 亚洲精品中文字幕成人片| 国外成人在线直播| 99精品美女视频在线观看热舞| 亚洲欧美一二三| 岛国av在线一区| 精品成人无码久久久久久| 综合激情国产一区| 日韩第一区第二区| 日韩国产欧美亚洲| 中文字幕免费在线观看视频一区| 可以免费看的av毛片| 一本大道亚洲视频| 久久精品九色| 国产网站免费在线观看| 国产精品美女一区二区在线观看| 国产夫妻性生活视频| 欧美一区二区.| 99久久九九| 在线免费播放av| 精品视频在线免费观看| 欧洲毛片在线| 成人国产精品一区二区| 在线电影一区| 国产探花视频在线| 欧美刺激午夜性久久久久久久| 浪潮色综合久久天堂 | av在线free| 欧美国产综合视频| 国产一区二区女| 日韩手机在线视频| 欧美成人合集magnet| 久草精品在线| 欧美熟妇另类久久久久久多毛| 色综合中文综合网| √天堂8在线网| 亚洲成人网上| 日韩av网站免费在线| 九九九在线视频| 最近2019中文字幕第三页视频|