国产无遮挡裸体免费直播视频,久久精品国产蜜臀av,动漫在线视频一区二区,欧亚日韩一区二区三区,久艹在线 免费视频,国产精品美女网站免费,正在播放 97超级视频在线观看,斗破苍穹年番在线观看免费,51最新乱码中文字幕

使用JavaScript 實(shí)現(xiàn)時(shí)間軸與動(dòng)畫效果的示例代碼(前端組件化)

 更新時(shí)間:2021年04月06日 17:56:26   作者:三鉆  
這篇文章主要介紹了使用JavaScript 實(shí)現(xiàn)時(shí)間軸與動(dòng)畫效果的示例代碼(前端組件化),本文重點(diǎn)給大家介紹基礎(chǔ)的動(dòng)畫類實(shí)現(xiàn)時(shí)間軸,通過示例代碼給大家介紹的很詳細(xì),需要的朋友可以參考下

上一篇文章《用 JSX 實(shí)現(xiàn) Carousel 輪播組件》中,我們實(shí)現(xiàn)了一個(gè) “基礎(chǔ)” 的輪播組件。為什么我們叫它 “基礎(chǔ)” 呢?因?yàn)槠鋵?shí)它看起來已經(jīng)可以滿足我們輪播組件的功能,但是其實(shí)它還有很多缺陷我們是沒有去完善的。

雖然我們已經(jīng)在里面實(shí)現(xiàn)了兩個(gè)功能,一是可以自動(dòng)輪播,二是可以手勢(shì)拖拽。但是其實(shí)它離一個(gè)真正意義上的可用程度還是有很遠(yuǎn)的距離的。

首先我們的自動(dòng)輪播和拖拽是無法無縫連接的,也就是說當(dāng)我們拖拽結(jié)束后,我們的輪播應(yīng)該繼續(xù)自動(dòng)輪播的。這一點(diǎn)我們是還沒有實(shí)現(xiàn)的。我們的拖拽本身也是有細(xì)節(jié)上的問題的,比方說它目前只支持鼠標(biāo)的拖拽事件,并不支持觸屏的拖拽,這個(gè)也是我們?cè)诰W(wǎng)頁研發(fā)過程中必須要去面對(duì)的問題。

第二我們動(dòng)畫是使用 CSS Animation 實(shí)現(xiàn)的,也不具備任何的自定義和相應(yīng)變化的。

所以接下來我們來一起實(shí)現(xiàn)我們的動(dòng)畫庫,但是實(shí)現(xiàn)動(dòng)畫庫之前,我們需要擁有一個(gè)動(dòng)畫庫中的時(shí)間軸庫。這篇文章我們先來看看怎么去實(shí)現(xiàn)一個(gè)時(shí)間軸類,和一個(gè)基礎(chǔ)的動(dòng)畫類來使用這個(gè)時(shí)間軸。

代碼整理

首先我們發(fā)現(xiàn)之前寫的 Carousel 組件的代碼已經(jīng)很復(fù)雜了,所以我們需要封裝一下它,這里我們就把它獨(dú)立放入一個(gè) JavaScript 文件中。

在項(xiàng)目根目錄,建立一個(gè) carousel.js,然后把我們 main.js 中 carousel 組件相關(guān)的代碼都移動(dòng)到 carousel.js 中。

carousel.js 中只需要 import Component 即可,然后給我們的 Carousel 類加上 export。代碼結(jié)構(gòu)如下:

import { Component } from './framework.js';

export class Carousel extends Component {/** Carousel 里面的代碼 */}

最后我們?cè)?main.js 中重新 import Carousel 組件即可。

import { Component, createElement } from './framework.js';
import { Carousel } from './carousel.js';

let gallery = [
 'https://source.unsplash.com/Y8lCoTRgHPE/1600x900',
 'https://source.unsplash.com/v7daTKlZzaw/1600x900',
 'https://source.unsplash.com/DlkF4-dbCOU/1600x900',
 'https://source.unsplash.com/8SQ6xjkxkCo/1600x900',
];

let a = <Carousel src={gallery} />;

// document.body.appendChild(a);
a.mountTo(document.body);

整理好我們的代碼,就可以開始寫我們的時(shí)間軸庫了。這個(gè)時(shí)間軸是我們動(dòng)畫庫中的一部分,所以我們統(tǒng)一放入我們動(dòng)畫庫的 JavaScript 文件中: animation.js。

我們是需要用這個(gè)時(shí)間軸去實(shí)現(xiàn)我們后續(xù)的動(dòng)畫庫的,而動(dòng)畫中就有一個(gè)非常關(guān)鍵的概念,就是 “

最基礎(chǔ)的動(dòng)畫能力,就是每幀執(zhí)行了一個(gè)事件。


JavaScript 中的 “幀”

因?yàn)槲覀冃枰小皫辈拍軐?shí)現(xiàn)我們的動(dòng)畫,所以我們需要先去了解 JavaScript 中的幾種處理幀的方案。

人眼能夠識(shí)別的動(dòng)畫的一個(gè)最高頻率就是 60 幀。

有的同學(xué)可能有看過李安導(dǎo)演的電影。比如,《比利·林恩的中場(chǎng)戰(zhàn)事》就是全世界第一個(gè) 120 幀拍攝和 120 幀播放的電影。

也是因?yàn)閹史叮院芏嗟胤骄蜁?huì)感到很絲滑。但是一般我們的游戲,包括我們的顯示器,它們支持的都是 60 幀。雖然我們看顯示器的設(shè)置中,可能會(huì)有 70、80 幀,但是一般軟件都會(huì)與 60 幀對(duì)其。

如果我們 1000 毫秒(一秒)里面需要 60 幀的話,那是多少毫秒是一幀呢?也就是 1000 / 60 = 16.666 1000 / 60 = 16.666 1000/60=16.666,所以 16 毫秒大概就是一幀的時(shí)間。

這個(gè)就是為什么我們一般都會(huì)用 16 毫秒作為一幀的時(shí)長(zhǎng)。


實(shí)現(xiàn)“幀”的方法

接下來我們來分析一下,有哪些方法可以在 JavaScript 中實(shí)現(xiàn) “幀”。

1. setInterval

第一種就是 setInterval,這個(gè)其實(shí)我們?cè)趯戄啿D的時(shí)候就用過。讓一個(gè)邏輯在每一幀中執(zhí)行,就是這樣的:

setInterval(() => {/** 一幀要發(fā)生的事情 */}, 16)

這里設(shè)置的時(shí)間隔,就是 16 毫秒,一幀的時(shí)長(zhǎng)。

2. setTimeout

我們也是可以使用 setTimeout 這個(gè)去重復(fù)處理一幀中的事件。但是因?yàn)?setTimeout 是只執(zhí)行一次的。所以我們需要給它一個(gè)函數(shù)名,方便我們后面重復(fù)調(diào)用它。

一般這種用來作為動(dòng)畫中的一幀的 setTimeout,都會(huì)命名為 tick。因?yàn)?tick 在英文中,就是我們時(shí)鐘秒針走了一秒時(shí)發(fā)出來的聲音,后面也用這個(gè)聲音作為一個(gè)單詞,來表達(dá)走了一幀/一秒。

我們的使用方式就是定義一個(gè) tick 函數(shù),讓它執(zhí)行一個(gè)邏輯/事件。然后使用 setTimeout 來加入一個(gè)延遲 16 毫秒后再執(zhí)行一次自己。

let tick = () => {
	/** 我們的邏輯/事件 */
 setTimout(tick, 16);
}

3. requestAnimationFrame

最后現(xiàn)代瀏覽器支持了一個(gè) requrestAnimationFrame(也叫 RAF)。這是在寫動(dòng)畫時(shí)比較常用,它不需要去定義一幀的時(shí)長(zhǎng)。

當(dāng)我們申請(qǐng)瀏覽器執(zhí)行下一幀的時(shí)候,就會(huì)執(zhí)行傳入 RAF 的 callback 函數(shù)。并且這個(gè)函數(shù)執(zhí)行的時(shí)間是與瀏覽器的幀率是相關(guān)的。

所以,如果我們要做一些瀏覽器的降幀、降頻的操作時(shí),那么 RAF 就可以跟著瀏覽的幀率一起下降。

使用也是非常簡(jiǎn)單:

let tick = () => {
	/** 我們的邏輯/事件 */
 setTimout(tick, 16);
}

所以,一般最常用的就是這三種方案。如果我們的用戶大部分都是使用現(xiàn)代瀏覽器的話,就推薦使用 requestAnimationFrame。

“為什么不用 setInterval 呢”?因?yàn)?setInterval 比較不可控,瀏覽器到底會(huì)不會(huì)按照我們?cè)O(shè)置的 16 毫秒去執(zhí)行呢?這個(gè)就不好說了。

還有一個(gè)就是,一旦我們這個(gè) tick 寫的不好,setInterval 就有可能發(fā)生積壓。因?yàn)樗枪潭?16 毫秒循環(huán)執(zhí)行的,所以 interval 之間是不會(huì)管上一個(gè) interval 中的代碼是否已經(jīng)執(zhí)行完,第二個(gè) interval 的代碼就會(huì)進(jìn)入 interval 的隊(duì)列。這個(gè)也是取決于瀏覽器的底層實(shí)現(xiàn),每一個(gè)瀏覽器有可能選擇不同的策略。

因?yàn)槲覀冞@里實(shí)現(xiàn)的動(dòng)畫庫,不需要考慮到舊瀏覽器的兼容性。我們這里就選擇使用 requestAnimationFrame。

接下來的時(shí)間軸庫中,我們就會(huì)使用 requestAnimationFrame 來做一個(gè)自重復(fù)的操作。

這里還要提到一個(gè)和 requestAnimationFrame 對(duì)應(yīng)的一個(gè) cancelAnimationFrame。如果我們聲明一個(gè)變量來儲(chǔ)存 requestAnimationFrame,我們就可以傳入這個(gè)變量到 cancelAnimationFrame 讓這個(gè)動(dòng)畫停止。

let tick = () => {
	let handler = requestAnimationFrame(tick);
 cancelAnimationFrame(handler);
}

這樣我們就可以避免一些資源的浪費(fèi)。


實(shí)現(xiàn) Timeline 時(shí)間軸

開頭我們講過,在做動(dòng)畫的時(shí)候,我們就需要把 tick 這個(gè)東西給包裝成一個(gè) Timeline

接下來我們就來一起實(shí)現(xiàn)這個(gè) Timeline(時(shí)間軸) 類。正常來講,我們一個(gè) Timeline 只要 start(開始)就可以了,并不會(huì)有一個(gè) stop(停止)的狀態(tài)。因?yàn)橐粋€(gè)時(shí)間軸,肯定是會(huì)一直播放到結(jié)束的,并沒有中間停止這樣的狀態(tài)。

不過它是會(huì)有 pause(暫停) 和 resume(恢復(fù))這種組合。而這一組狀態(tài)也是 Timeline 中非常重要的功能。比如,我們寫了一大堆的動(dòng)畫,我們就需要把它們都放到同一個(gè)動(dòng)畫 Timeline 里面去執(zhí)行,而在執(zhí)行的過程中,我可以讓所有這些動(dòng)畫暫停和恢復(fù)播放。

另外就是這個(gè) rate(播放速率),不過這個(gè)不是所有的時(shí)間線都會(huì)提供。rate 會(huì)有兩種方法,一個(gè)是 set、一個(gè)是 get。因?yàn)椴シ诺乃俾适菚?huì)有一個(gè)倍數(shù)的,我們可以讓動(dòng)畫快進(jìn)、慢放都是可以的。

在設(shè)計(jì)這個(gè)動(dòng)畫庫時(shí),還有一個(gè)非常重要的概念,叫 reset(重啟)。這個(gè)會(huì)把整個(gè)時(shí)間軸清理干凈,這樣我們就可以去復(fù)用一些時(shí)間線。

這個(gè)教程中實(shí)現(xiàn)的 set 和 get 的 rate 就不做了,因?yàn)檫@個(gè)是比較高級(jí)的時(shí)間線功能。如果我們要做這個(gè)就要講很多相關(guān)的知識(shí)。但是 pauseresume 對(duì)于我們的 carousel(輪播圖)是至關(guān)重要的,所以這里我們是一定要實(shí)現(xiàn)的。

講了那么多,我們趕緊開工吧!~

實(shí)現(xiàn) start 函數(shù)

在我們的 start 方法中,就會(huì)有一個(gè)啟動(dòng) tick 的過程。這里我們會(huì)選擇把這個(gè) tick 變成一個(gè)私有的方法(把它藏起來)。不然的話,這個(gè) tick 誰都可以調(diào)用,這樣很容易就會(huì)被外部的使用者破壞掉整個(gè) Timeline 類的狀態(tài)體系。

那么我們?cè)趺床拍馨?tick 完美的藏起來呢?我們會(huì)在 animation.js 這個(gè)文件的全局域中聲明一個(gè)常量叫 TICK。并且用 Symbol 來創(chuàng)建一個(gè) tick。這樣除了在 animation.js 當(dāng)中可以獲取到我們的 tick 之外,其他任何地方都是無法獲得 tick 這個(gè) Symbol 的。

同理 tick 中的 requestAnimationFrame 也同樣可以創(chuàng)建一個(gè)全局變量 TICK_HANDLER 來儲(chǔ)存。這個(gè)變量也會(huì)使用一個(gè) Symbol 來包裹起來,這樣就可以限定只能在本文件中使用。

對(duì) Symbol 不是很熟悉的同學(xué),其實(shí)我們可以理解它為一種 “特殊字符”。就算我們把兩個(gè)傳入 Symbol 的 key 都叫 ‘tick',創(chuàng)建出來的兩個(gè)值都會(huì)是不一樣的。這個(gè)就是 Symbol 的一個(gè)特性。

其實(shí)我們之前的《前端進(jìn)階》的文章中也有詳細(xì)講過和使用過 Symbol。比如,我們使用過 Symbol 來代表 EOF(End Of File)文件結(jié)束符號(hào)。所以它作為對(duì)象的一個(gè) key 并不是唯一的用法,Symbol 這種具有唯一特性,是它存在的一個(gè)意義。

有了這兩個(gè)常量,我們就可以在 Timeline 類的構(gòu)造函數(shù)中初始化 tick。

初始化好 Tick 我們就可以在 start 函數(shù)中直接調(diào)用全局中的 TICK。這樣我們 Timeline(時(shí)間線)中的時(shí)間就開始以 60 幀的播放率開始運(yùn)行。

最后代碼就是如下:

const TICK = Symbol('tick');
const TICK_HANDLER = Symbol('tick-handler');

export class Timeline {
 constructor() {
 this[TICK] = () => {
 console.log('tick');
 requestAnimationFrame(this[TICK]);
 };
 }
 start() {
 this[TICK]();
 }
 pause() {}
 resume() {}
 reset() {}
}

完成到這一部分,我們就可以把這個(gè) Timeline 類引入我們的 main.js 里面試試。

import { Timeline } from './animation.js';

let tl = new Timeline();

tl.start();

Build 一下我們的代碼,然后在瀏覽器運(yùn)行,這時(shí)候就可以看到在 console 中,我們的 tick 是正常在運(yùn)行了。這說明我們 Timeline 目前的邏輯是寫對(duì)了。

到這里,我們實(shí)現(xiàn)了一個(gè)非?;镜臅r(shí)間線的操作。接下來我們來實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 Animation(動(dòng)畫)類來測(cè)試我們的時(shí)間軸。

實(shí)現(xiàn) Animation 類

接下來我們給 Tick 添加一個(gè) animation(動(dòng)畫),并且執(zhí)行這個(gè)動(dòng)畫。

我們做的這個(gè)時(shí)間軸,最終是需要用在我們的 Carousel(輪播圖)的動(dòng)畫上的。而輪播圖上的動(dòng)畫,我們稱它為 “屬性動(dòng)畫”。

因?yàn)槲覀兪前岩粋€(gè)對(duì)象的某一個(gè)屬性,從一個(gè)值變成量外一個(gè)值。

與屬性動(dòng)畫相對(duì)的還有幀動(dòng)畫,也就是每一秒都來一張圖片。講到幀動(dòng)畫,我們應(yīng)該都知道 “宮崎駿” 老師的動(dòng)畫,比如,經(jīng)典的《龍貓》、《天空之城》等等。這些動(dòng)畫都是 “宮崎駿” 老師一張一張圖畫出來的,然后每一幀播放一張圖片,在一個(gè)快速播放的過程,就會(huì)讓我們看到圖中的人和物在動(dòng)了。比動(dòng)漫時(shí)代更早的時(shí)候也已經(jīng)有動(dòng)畫了,也就是我們古人所說的走馬燈。

上面說到的動(dòng)畫,都不是通過屬性來做的。但是我們?cè)跒g覽器里面做的,大部分都是屬性的動(dòng)畫。每個(gè)動(dòng)畫都會(huì)有一個(gè)初始屬性值和終止屬性值。

了解完動(dòng)畫的理論后,我們就可以開始實(shí)現(xiàn)這部分的邏輯。首先我們 Animation(動(dòng)畫)這部分的邏輯和 Timeline 也是相對(duì)獨(dú)立的,所以這里我們可以把 Animation 單獨(dú)封裝成一個(gè)類。(我們后面的前端組件化的文章中還會(huì)再次強(qiáng)化動(dòng)畫庫的功能。

export class Animation {
 constructor() {}
}

首先創(chuàng)建一個(gè) Animation(動(dòng)畫)我們需要以下參數(shù):

  • object:被賦予動(dòng)畫的元素對(duì)象
  • property:被賦予動(dòng)畫變動(dòng)的屬性
  • startValue:動(dòng)畫起始值
  • endValue:動(dòng)畫終止值
  • duration:動(dòng)畫時(shí)長(zhǎng)
  • timingFunction:動(dòng)畫與時(shí)間的曲線

這里我們需要注意的是,傳入的 property(屬性)一般來說都是帶有一個(gè)單位的,比如:px(像素)。因?yàn)槲覀兊?startValueendValue 一定是一個(gè) JavaScript 里面的一個(gè)數(shù)值。那么如果我們想要一個(gè)完整的 Animation,我們還需要傳入更多的參數(shù)。

但是這里我們就先不往后加,先實(shí)現(xiàn)一個(gè)簡(jiǎn)單的 Animation 。

初始化我們的 Animation 對(duì)象時(shí),我們是需要把所有傳入的參數(shù)都存儲(chǔ)到這個(gè)對(duì)象的屬性中,所以在 constructor 這里我們就要把所有傳入的參數(shù)的原封不動(dòng)的抄寫一遍。

export class Animation {
 constructor(object, property, startValue, endValue, duration, timingFunction) {
 this.object = object;
 this.property = property;
 this.startValue = startValue;
 this.endValue = endValue;
 this.duration = duration;
 this.timingFunction = timingFunction;
 }
}

接下來我們需要一個(gè)執(zhí)行 animation(動(dòng)畫)的函數(shù),我們叫它為 exec、go 都是可以的,這里我們就用 run(運(yùn)行)這個(gè)單詞。個(gè)人覺得更加貼切這個(gè)函數(shù)的作用。

這個(gè)函數(shù)是需要接收一個(gè) time(時(shí)間)參數(shù),而這個(gè)是一個(gè)虛擬時(shí)間。如果我們用真實(shí)的時(shí)間其實(shí)我們根本不需要做一個(gè) Timeline(時(shí)間軸)了。

有了這個(gè)時(shí)間,我們就可以根據(jù)這個(gè)時(shí)間計(jì)算當(dāng)前動(dòng)畫的屬性應(yīng)該變化多少。要計(jì)算這個(gè)屬性的變化,我們首先需要知道動(dòng)畫初始值到終止值的總變化區(qū)間。

公式:變化區(qū)間(range) = 終止值(endValue) - 初始值(startValue)

得到了 變換區(qū)間 后,我們就可以計(jì)算出每一幀這個(gè)動(dòng)畫要變化多少,這個(gè)公式就是這樣的:

變化值 = 變化區(qū)間值(range) * 時(shí)間(time) / 動(dòng)畫時(shí)長(zhǎng)(duration)

這里得到的變化值,會(huì)根據(jù)當(dāng)前已經(jīng)執(zhí)行的時(shí)間與動(dòng)畫的總時(shí)長(zhǎng)算出一個(gè) progression(進(jìn)度 %),然后用這個(gè)進(jìn)度的百分比與變化區(qū)間,算出我們初始值到達(dá)當(dāng)前進(jìn)度的值的差值。這個(gè)差值就是我們的 變化值。

這個(gè)變化值,就相等于我們 CSS animation 中的 linear 動(dòng)畫曲線。這動(dòng)畫曲線就是一條直線。這里我們先用這個(gè)實(shí)現(xiàn)我們的 Animation 類,就先不去處理我們的 timingFunction,后面我們?cè)偃ヌ幚磉@個(gè)動(dòng)態(tài)的動(dòng)畫曲線。

有了這個(gè)變化值,我們就可以用 startValue(初始值)+ 變化值,得到當(dāng)前進(jìn)度對(duì)應(yīng)的屬性值。我們的代碼就是這樣實(shí)現(xiàn)的:

run(time) {
 let range = this.endValue - this.startValue;
 this.object[this.property] = this.startValue + (range * time) / this.duration;
}

這樣 Animation 就可以運(yùn)作的了。接下來我們把這個(gè) Animation 添加到 Timeline 的 animation 隊(duì)列里面,讓它在隊(duì)列中被執(zhí)行。

我們上面說到,這個(gè) Animation 中的 run 方法接收的 time(時(shí)間)是一個(gè)虛擬的時(shí)間。所以在 Timeline 中調(diào)用這個(gè) run 方法的時(shí)候就要把一個(gè)虛擬時(shí)間傳給 Animation,這樣我們的動(dòng)畫就可以運(yùn)作了。

好,這里我們要添加 animation 到 timeline 里面,首先我們就要有一個(gè) animations 隊(duì)列。這個(gè)我們就直接生成一個(gè) animations Set。

這個(gè)與其他 Timeline 中的儲(chǔ)存方式一樣,我們建立一個(gè)全局的 ANIMATIONS 常量來儲(chǔ)存,它的值就用 Symbol 包裹起來。這樣就可以避免這個(gè)隊(duì)列不小心被外部調(diào)用到了。

const ANIMATIONS = Symbol('animations');

這個(gè)隊(duì)列還需要在 Timeline 類構(gòu)造的時(shí)候,就賦值一個(gè)空的 Set。

constructor() {
 this[ANIMATIONS] = new Set();
}

有隊(duì)列,那么我們必然就需要有一個(gè)加入隊(duì)列的方法,所以我們?cè)?Timeline 類中還要加入一個(gè) add() 方法。實(shí)現(xiàn)邏輯如下:

constructor() {
 this[ANIMATIONS] = new Set();
}

我們要在 Timeline 中給 Animation 的 run 傳一個(gè)當(dāng)前已經(jīng)執(zhí)行了的時(shí)長(zhǎng)。要計(jì)算這個(gè)時(shí)長(zhǎng)的話,就要在 Timeline 開始的時(shí)候就記錄好一個(gè)開始時(shí)間。然后每一個(gè)動(dòng)畫被觸發(fā)的時(shí)候,用 當(dāng)前時(shí)間 - Timeline 開始時(shí)間 才能獲得當(dāng)前已經(jīng)運(yùn)行了多久。

但是之前的 tick 是寫在了 constructor 里面,Timeline 開始時(shí)間必然是放在 start 方法之中,所以為了能夠更方便的可以獲得這個(gè)時(shí)間,我們可以直接把 tick 聲明放到 start 里面。

雖然說這個(gè)改動(dòng)會(huì)讓我們每次 Timeline 啟動(dòng)的時(shí)候,都會(huì)重新構(gòu)建一個(gè) tick 對(duì)象函數(shù)。但是這種方法會(huì)更便于快速實(shí)現(xiàn)這個(gè)功能,不過想要性能更好的同學(xué)也是可以優(yōu)化這一個(gè)地方的。

移動(dòng)完我們 tick 之后,我們就可以在 tick 里面加入調(diào)用 ANIMATIONS 隊(duì)列的 animation(動(dòng)畫)了。因?yàn)橐粋€(gè) Timeline 里面可以有多個(gè)animation,并且每一幀都會(huì)推動(dòng)他們到下一個(gè)進(jìn)度的屬性狀態(tài)。所以這里我們就用一個(gè)循環(huán),然后調(diào)用一遍我們 ANIMATIONS 隊(duì)列里面的所有的 animation 的 run 方法。

最后我們的代碼就是這樣的:

const TICK = Symbol('tick');
const TICK_HANDLER = Symbol('tick-handler');
const ANIMATIONS = Symbol('animations');

export class Timeline {
 constructor() {
 this[ANIMATIONS] = new Set();
 }
 start() {
 let startTime = Date.now();
 this[TICK] = () => {
 let t = Date.now() - startTime;
 for (let animation of this[ANIMATIONS]) {
 animation.run(t);
 }
 requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
 }
 pause() {}
 resume() {}
 reset() {}
 add(animation) {
 this[ANIMATIONS].add(animation);
 }
}

export class Animation {
 constructor(object, property, startValue, endValue, duration, timingFunction) {
 this.object = object;
 this.property = property;
 this.startValue = startValue;
 this.endValue = endValue;
 this.duration = duration;
 this.timingFunction = timingFunction;
 }

 run(time) {
 console.log(time);
 let range = this.endValue - this.startValue;
 this.object[this.property] = this.startValue + (range * time) / this.duration;
 }
}

我們?cè)?animation 的 run 方法中,加入一個(gè) console.log(time),方便我們調(diào)試。

最后我們?cè)?main.js 中,把 animation 加到我們的 Timeline 中。

import { Component, createElement } from './framework.js';
import { Carousel } from './carousel.js';
import { Timeline, Animation } from './animation.js';

let gallery = [
 'https://source.unsplash.com/Y8lCoTRgHPE/1600x900',
 'https://source.unsplash.com/v7daTKlZzaw/1600x900',
 'https://source.unsplash.com/DlkF4-dbCOU/1600x900',
 'https://source.unsplash.com/8SQ6xjkxkCo/1600x900',
];

let a = <Carousel src={gallery} />;

// document.body.appendChild(a);
a.mountTo(document.body);

let tl = new Timeline();
// tl.add(new Animation({}, 'property', 0, 100, 1000, null));

tl.start();

我們發(fā)現(xiàn) Animation 確實(shí)可以運(yùn)作了,時(shí)間也可以獲得了。但是也發(fā)現(xiàn)了一個(gè)問題,Animation 一直在播放沒有停止。

那么我們就要給它加入一個(gè)終止條件。我們這個(gè)條件判斷應(yīng)該放在執(zhí)行 animation.run 之前,如果當(dāng)前的時(shí)間已經(jīng)超過了動(dòng)畫的時(shí)長(zhǎng)。這個(gè)時(shí)候我們就需要停止執(zhí)行動(dòng)畫了。

首先我們需要改造 start 函數(shù)中的 animation 循環(huán)調(diào)用,在執(zhí)行 animation.run 之前加入一個(gè)條件判斷。這里我們需要判斷如果當(dāng)前時(shí)間是否已經(jīng)大于 animation 中的 duration 動(dòng)畫時(shí)長(zhǎng)。如果成立動(dòng)畫就可以停止執(zhí)行了,并且需要把這個(gè) animation 移除 ANIMATIONS 隊(duì)列。

export class Timeline {
 constructor() {
 this[ANIMATIONS] = new Set();
 }
 start() {
 let startTime = Date.now();
 this[TICK] = () => {
 let t = Date.now() - startTime;
 for (let animation of this[ANIMATIONS]) {
 if (t > animation.duration) {
  this[ANIMATIONS].delete(animation);
 }
 animation.run(t);
 }
 requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
 }
 pause() {}
 resume() {}
 reset() {}
 add(animation) {
 this[ANIMATIONS].add(animation);
 }
}

就這樣我們就加入了停止條件了,并沒有什么復(fù)雜的邏輯。最后我們?cè)?main.js 中,改一下 Animation 的第一個(gè)參數(shù)。在傳入的對(duì)象中加入一個(gè) setter,這樣我們就可以讓我們的 animation 打印出時(shí)間。這樣方便我們調(diào)試。

tl.add(
 new Animation(
 {
 set a(a) {
 console.log(a);
 },
 },
 'property',
 0,
 100,
 1000,
 null
 )
);

我們看到動(dòng)畫確實(shí)是停止了,但是還是有一個(gè)問題。我們?cè)O(shè)置的 duration 動(dòng)畫時(shí)長(zhǎng)是到 1000 毫秒,但是這里最后一個(gè)是 1002,明顯超出了我們的動(dòng)畫時(shí)長(zhǎng)。

所以我們是需要在遇到動(dòng)畫結(jié)束條件的時(shí)候,需要給 animation 傳入它的 duration(動(dòng)畫時(shí)長(zhǎng)的值)。這里我們就應(yīng)該這樣寫:

start() {
 let startTime = Date.now();
 this[TICK] = () => {
 let t = Date.now() - startTime;
 for (let animation of this[ANIMATIONS]) {
 let t0 = t;
 if (t > animation.duration) {
  this[ANIMATIONS].delete(animation);
  t0 = animation.duration;
 }
 animation.run(t0);
 }
 requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
 }
 pause() {}
 resume() {}
 reset() {}
 add(animation) {
 this[ANIMATIONS].add(animation);
 }
}

這樣我們初步的 Timeline 和 Animation 的能力就建立起來了。


設(shè)計(jì)時(shí)間線的更新

接下來我們就給這個(gè) Timeline 加入更多的功能,讓我們 Animation 這個(gè)庫變成真正的可用 。

在 CSS Animation 動(dòng)畫中,我們知道它有一個(gè) duration(動(dòng)畫時(shí)長(zhǎng)),其實(shí)同時(shí)還會(huì)有一個(gè) delay(動(dòng)畫延遲時(shí)間)。

那么首先我們先來嘗試添加這個(gè)功能。

添加 Delay 屬性支持

在開發(fā)當(dāng)中,當(dāng)我們要去給原有的庫添加功能。我們首先要考慮的是 “找到一個(gè)合理的地方去添加這個(gè)功能”。

其實(shí)直觀的來說,我們第一感覺是會(huì)想把這個(gè) delay 放入 Animation 類當(dāng)中,畢竟這個(gè)功能屬于動(dòng)畫的一部分。但是這里有一個(gè)更好的思路,就是把 delay 放到 Timeline 里面。

我們可以這么理解,一個(gè)動(dòng)畫的開始時(shí)間、終止時(shí)間、時(shí)間的控制,都是 Timeline 時(shí)間軸的相關(guān)事務(wù),其實(shí)與 Animation 關(guān)注的是有區(qū)別的。而 Animation 我覺得更多是關(guān)注動(dòng)畫的效果,運(yùn)行等事務(wù)。

所以 delay 放在 Timeline 顯然是更加合適的。

在 Timeline 的 add() 方法中,添加 animation 到隊(duì)列的時(shí)候,給它添加一個(gè) delay。

在添加 delay 這個(gè)邏輯的同時(shí),我們還可以處理掉一個(gè)問題。就是當(dāng)我們?cè)谔砑?animation 動(dòng)畫到隊(duì)列的時(shí)候,可能 Timeline 已經(jīng)在執(zhí)行了。這樣其實(shí)我們加入動(dòng)畫的時(shí)候,我們動(dòng)畫的開始時(shí)間是不對(duì)的。

另外還有一個(gè)問題,就是在 start 方法中,我們的 t 開始時(shí)間和 t0 其實(shí)不一定一致的。因?yàn)槲覀兊?startTime 是可以根據(jù) delay 被手動(dòng)定義的。所以這一個(gè)值也是需要我們重新去編寫一下邏輯的。

好,那么在實(shí)現(xiàn)我們的 delay 功能的同時(shí),我們就可以把這兩個(gè)因素都涵蓋進(jìn)去。

首先我們來加入一個(gè) delay 參數(shù):

export class Animation {
 constructor(object, property, startValue, endValue, duration, delay, timingFunction) {
 this.object = object;
 this.property = property;
 this.startValue = startValue;
 this.endValue = endValue;
 this.duration = duration;
 this.timingFunction = timingFunction;
 this.delay = delay;
 }

 run(time) {
 console.log(time);
 let range = this.endValue - this.startValue;
 this.object[this.property] = this.startValue + (range * time) / this.duration;
 }
}

這里無非就是給 constructor 中,加入一個(gè) delay 參數(shù),并且存儲(chǔ)到類的屬性對(duì)象當(dāng)中。

因?yàn)槊恳粋€(gè)加入 Timeline 隊(duì)列的 Animation 動(dòng)畫都可能有不一樣的 delay,也就是說有不一樣的開始動(dòng)畫的時(shí)間。所以我們需要在 Timeline 類中的 constructor 下建立一個(gè) START_TIMES 存儲(chǔ)空間,把我們所有 Animation 對(duì)應(yīng)的開始時(shí)間都存儲(chǔ)起來。

export class Animation {
 constructor(object, property, startValue, endValue, duration, delay, timingFunction) {
 this.object = object;
 this.property = property;
 this.startValue = startValue;
 this.endValue = endValue;
 this.duration = duration;
 this.timingFunction = timingFunction;
 this.delay = delay;
 }

 run(time) {
 console.log(time);
 let range = this.endValue - this.startValue;
 this.object[this.property] = this.startValue + (range * time) / this.duration;
 }
}

然后在 Timeline 加入動(dòng)畫的 add 方法中,把動(dòng)畫的開始時(shí)間加入到 START_TIMES 數(shù)據(jù)里面。如果使用者沒有給 add 方法傳入 startTime 參數(shù),那么我們需要給它一個(gè)默認(rèn)值為 Date.now() 。

add(animation, startTime) {
 if (arguments.length < 2) startTime = Date.now();
 this[ANIMATIONS].add(animation);
 this[START_TIMES].set(animation, startTime);
}

接下來我們就可以去改造開始時(shí)間的邏輯:

  • 第一種情況: 如果我們動(dòng)畫的開始時(shí)間是小于,Timeline 的開始時(shí)間的,那么我們當(dāng)前動(dòng)畫的時(shí)間進(jìn)度就是 當(dāng)前時(shí)間 - Timeline 開始時(shí)間
  • 第二種情況: 動(dòng)畫的開始時(shí)間大于 Timeline 的開始時(shí)間,那么當(dāng)前動(dòng)畫的時(shí)間進(jìn)度就是 當(dāng)前時(shí)間 - 動(dòng)畫的開始時(shí)間

代碼實(shí)現(xiàn)如下:

start() {
 let startTime = Date.now();
 this[TICK] = () => {
 let now = Date.now();
 for (let animation of this[ANIMATIONS]) {
 let t;

 if (this[START_TIMES].get(animation) < startTime) {
 t = now - startTime;
 } else {
 t = now - this[START_TIMES].get(animation);
 }

 if (t > animation.duration) {
 this[ANIMATIONS].delete(animation);
 t = animation.duration;
 }
 animation.run(t);
 }
 requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
}

這樣 Timline 就支持隨時(shí)給它加入一個(gè) animation 動(dòng)畫。為了方便我們測(cè)試這個(gè)新的功能,我們把 tlanimation 都掛載在 window 上。

這里我們就改動(dòng)一下 main.js 中的代碼:

start() {
 let startTime = Date.now();
 this[TICK] = () => {
 let now = Date.now();
 for (let animation of this[ANIMATIONS]) {
 let t;

 if (this[START_TIMES].get(animation) < startTime) {
 t = now - startTime;
 } else {
 t = now - this[START_TIMES].get(animation);
 }

 if (t > animation.duration) {
 this[ANIMATIONS].delete(animation);
 t = animation.duration;
 }
 animation.run(t);
 }
 requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
}

我們重新 webpack 打包后,就可以在 console 里面執(zhí)行以下命令來給 Timeline 加入一個(gè)動(dòng)畫:

tl.add(animation);

好,這個(gè)就是 Timeline 更新的設(shè)計(jì)。但是寫到這里,我們其實(shí)還沒有去讓 delay 這個(gè)參數(shù)的值去讓動(dòng)畫被延遲。

其實(shí)這里無非就在 t 的計(jì)算中,最后減去 animation.delay 即可。

if (this[START_TIMES].get(animation) < startTime) {
 t = now - startTime - animation.delay;
} else {
 t = now - this[START_TIMES].get(animation) - animation.delay;
}

但是我們需要注意一種特殊情況,如果我們 t - 延遲時(shí)間 得出的時(shí)間是小于 0 的話,那么代表我們的動(dòng)畫還沒有到達(dá)需要執(zhí)行的時(shí)間,只有 t > 0 才需要執(zhí)行動(dòng)畫。所以最后在執(zhí)行動(dòng)畫的邏輯上,加入一個(gè)判斷。

if (t > 0) animation.run(t);

那么接下來我們來嘗試實(shí)現(xiàn)它的 pause(暫停) 和 resume(恢復(fù)) 的能力。


實(shí)現(xiàn)暫停和重啟功能

首先我們來嘗試加入暫停的功能。

實(shí)現(xiàn) Pause

要給 Timeline 實(shí)現(xiàn) Pause 的能力,首先我們就要把 tick 給 cancel 掉。也就是讓我們 Timline 的時(shí)間停止,如果一個(gè)鐘或者手表的秒針不再動(dòng)了,那么時(shí)間自然就停止了。

要取消掉 tick ,首先我們要知道觸發(fā)的這個(gè) tick 在運(yùn)作的是什么。毋庸置疑,就是我們的 requestAnimationFrame。

還記得我們一開始聲明的 TICK_HANDLER 嗎?這個(gè)常量就是用來存儲(chǔ)我們當(dāng)前 tick 的事件的。

所以第一步就是用 TICK_HANDLER 來儲(chǔ)存我們的 requestAnimationFrame。tick 的啟動(dòng)是在我們 Timeline 類中的 start 方法中啟動(dòng)的,所以這里我們需要改動(dòng) start 方法中的 requestAnimationFrame

start() {
let startTime = Date.now();
 this[TICK] = () => {
 let now = Date.now();
 for (let animation of this[ANIMATIONS]) {
 let t;

 if (this[START_TIMES].get(animation) < startTime) {
 t = now - startTime - animation.delay;
 } else {
 t = now - this[START_TIMES].get(animation) - animation.delay;
 }

 if (t > animation.duration) {
 this[ANIMATIONS].delete(animation);
 t = animation.duration;
 }
 if (t > 0) animation.run(t);
 }
 this[TICK_HANDLER] = requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
}

然后我們?cè)?pause() 方法中調(diào)用以下 cancelAnimationFrame

pause() {
 cancelAnimationFrame(this[TICK_HANDLER]);
}

Pause(暫停) 還是比較簡(jiǎn)單的,但是 resume(重啟)就比較復(fù)雜了。

實(shí)現(xiàn) Resume

那么實(shí)現(xiàn) resume 的第一步必然就是重新啟動(dòng) tick。但是 tick 中的 t(動(dòng)畫開始時(shí)間)肯定是不對(duì)的,所以我們要想辦法去處理 pause 當(dāng)中的邏輯。

在實(shí)現(xiàn) Resume 之前,我們需要弄一點(diǎn) DOM 的東西來測(cè)試它。所以我們先建立一個(gè)新的 HTML,在里面建立一個(gè) div 元素。

<!-- 新建立一個(gè) animation.html (放在 dist 文件夾里面) -->

<style>
.box {
 width: 100px;
 height: 100px;
 background-color: aqua;
}
</style>

<body>
 <div class="box"></div>
 <script src="./main.js"></script>
</body>

然后我們也不用 main.js 了,另外建立一個(gè) animation-demo.js 來實(shí)現(xiàn)我們的動(dòng)畫調(diào)用。這樣我們就不需要和我們的 carousel 混攪在一起了。

// 在根目錄建立一個(gè) `animation-demo.js`
import { Timeline, Animation } from './animation.js';

let tl = new Timeline();

tl.start();
tl.add(
 new Animation(
 {
 set a(a) {
 console.log(a);
 },
 },
 'property',
 0,
 100,
 1000,
 null
 )
);

因?yàn)槲覀冃薷牧宋覀冺撁媸褂玫?js 入口文件。所以這里我們需要去 webpack.config.js 把 entry 改為 animation-demo.js。

module.exports = {
 entry: './animation-demo.js',
 mode: 'development',
 devServer: {
 contentBase: './dist',
 },
 module: {
 rules: [
 {
 test: /\.js$/,
 use: {
  loader: 'babel-loader',
  options: {
  presets: ['@babel/preset-env'],
  plugins: [['@babel/plugin-transform-react-jsx', { pragma: 'createElement' }]],
  },
 },
 },
 ],
 },
};

目前我們的 JavaScript 中是一個(gè)模擬的動(dòng)畫輸出。接下來我們嘗試給動(dòng)畫可以操縱一個(gè)元素的能力。

我們先給元素加一個(gè) id="el",方便我們?cè)谀_本中獲取到這個(gè)元素。

<div class="box" id="el"></div>

然后我們就可以對(duì)這個(gè)原形進(jìn)行動(dòng)畫的操作了。首先我們需要回到 animation-demo.js,把 Animation 實(shí)例化的第一個(gè)參數(shù)改為 document.querySelector('#el').style

然后第二個(gè)參數(shù)的屬性就改為 "transform"。但是這里要注意,后面的開始時(shí)間和結(jié)束時(shí)間是無法用于 transform 這個(gè)屬性的。

所以我們需要有一個(gè)轉(zhuǎn)換的 template(模版),通過使用這個(gè)模版來轉(zhuǎn)換時(shí)間成 transform 對(duì)應(yīng)的值。

這里的 template 值就直接寫成一個(gè)函數(shù):

 v => `translate(${$v}px)`;

最后我們的代碼就是這樣的:

tl.add(
 new Animation(
 document.querySelector('#el').style,
 'transform',
 0,
 100,
 1000,
 0,
 null,
 v => `translate(${v}px)`
 )
);

這部分調(diào)整好之后,我們需要去到 animation.js 中去做對(duì)應(yīng)的調(diào)整。

首先是給 Animation 類的 constructor 加入 template 參數(shù)的接收。與其他屬性一樣,在 constructor 中只是做一個(gè)存儲(chǔ)的操作。

然后在 Animation 中的 run 方法,在 this.object[this.property] 這里面的值就應(yīng)該調(diào)用 template 方法來生成屬性值。而不是之前那樣直接賦值給某一個(gè)屬性了。

export class Animation {
 constructor(
 object, 
 property,
 startValue,
 endValue,
 duration,
 delay,
 timingFunction,
 template
 ) {
 this.object = object;
 this.property = property;
 this.startValue = startValue;
 this.endValue = endValue;
 this.duration = duration;
 this.timingFunction = timingFunction;
 this.delay = delay;
 this.template = template;
 }

 run(time) {
 let range = this.endValue - this.startValue;
 this.object[this.property] = 
 this.template(
 this.startValue + (range * time) / this.duration
 );
 }
}

最后效果如下:

我們發(fā)現(xiàn),已經(jīng)可以用我們的 Animation 庫來控制元素的動(dòng)畫了。

首先我們來調(diào)整一下這些動(dòng)畫的參數(shù),讓開始到結(jié)束位置改為 0 到 500,然后動(dòng)畫的時(shí)間長(zhǎng)改為 2000 毫秒。這樣的設(shè)置,有利于我們調(diào)試后面的功能。

tl.add(
 new Animation(
 document.querySelector('#el').style,
 'transform',
 0,
 500,
 2000,
 0,
 null,
 v => `translate(${v}px)`
 )
);

好,接下來我們一起去加一個(gè) Pause 按鈕。

<body>
 <div class="box" id="el"></div>
 <button id="pause-btn">Pause</button>
 <script src="./main.js"></script>
</body>

然后我們回到 animation-demo.js 里面去綁定這個(gè)元素。并且讓他執(zhí)行我們 Timeline 中的 pause 方法。

document.querySelector('#pause-btn').addEventListener(
 'click',
 () => tl.pause()
);

我們可以看到,現(xiàn)在 pause 功能是可以的了,但是我們應(yīng)該怎么去讓這個(gè)動(dòng)畫繼續(xù)播下去呢?也就是要實(shí)現(xiàn)一個(gè) resume 的功能。

在實(shí)現(xiàn)這個(gè) resume 功能的邏輯之前,我們先用同樣的方式建立一個(gè) resume 的按鈕。并且讓這個(gè)按鈕調(diào)用我們 Timeline 里面的 resume() 方法。

<!-- animation.html -->

<body>
 <div class="box" id="el"></div>
 <button id="pause-btn">Pause</button>
 <button id="resume-btn">Resume</button>
 <script src="./main.js"></script>
</body>
// animation-demo.js 中加入 resume 按鈕事件綁定。

document.querySelector('#resume-btn').addEventListener(
 'click',
 () => tl.resume()
);

根據(jù)我們上面講到的邏輯,resume 最基本的理解,就是重新啟動(dòng)我們的 tick。那么我們就試試直接在 resume 方法中執(zhí)行 this[TICK]() 會(huì)怎么樣。

resume() {
 this[TICK]();
}

在動(dòng)畫中,我們可以看到,如果我們直接在 resume 中執(zhí)行 tick 的話,重新開始動(dòng)畫的盒子,并沒有在原來暫停的位置開始繼續(xù)播放動(dòng)畫。而是跳到了后面。

很顯然,在我們點(diǎn)擊 resume 的時(shí)候,我們的動(dòng)畫并沒有記住我們暫停時(shí)候的位置。所以在我們動(dòng)畫暫停的同時(shí),我們需要把 暫停的開始時(shí)間暫停時(shí)間給記錄下來。

這兩個(gè)變量因?yàn)槭切枰?Animation 類中使用的,所以這里要把它們定義在全局作用域之中。那么我們就用 PAUSE_STARTPAUSE_TIME 兩個(gè)常量來保存他們。

const PAUSE_START = Symbol('pause-start');
const PAUSE_TIME = Symbol('pause-time');

接下來就是在我們暫停的時(shí)候記錄一下當(dāng)時(shí)的時(shí)間:

pause() {
 this[PAUSE_START] = Date.now();
 cancelAnimationFrame(this[TICK_HANDLER]);
}

其實(shí)我們記錄暫停的開始時(shí)間是為了什么呢?就是為了在我們繼續(xù)播放動(dòng)畫的時(shí)候,知道我們當(dāng)下距離開始暫停的時(shí)候的時(shí)間相差了多久。

剛剛我們?cè)趧?dòng)畫里看到的現(xiàn)象是什么?就是我們重新啟動(dòng) tick 的時(shí)候,動(dòng)畫的開始時(shí)間使用了當(dāng)前的時(shí)間。這里說到的 “當(dāng)前” 時(shí)間,就是 Timeline 已經(jīng)跑到了哪里。顯然這個(gè)開始時(shí)間是不正確的。

如果我們?cè)跁和5臅r(shí)候,記錄了那一刻的時(shí)間。然后在點(diǎn)擊 resume 的時(shí)候計(jì)算暫停開始到點(diǎn)擊 resume 時(shí)的時(shí)長(zhǎng)。這樣我們就可以用 tick 中的 t(動(dòng)畫開始時(shí)間)- 暫停時(shí)長(zhǎng) = 當(dāng)前動(dòng)畫應(yīng)該繼續(xù)播放的時(shí)間。

使用這個(gè)算法,我們就可以讓我們的動(dòng)畫,精確的在原來暫停的位置繼續(xù)開始播放了。

接下來,我們來看看代碼的邏輯怎么實(shí)現(xiàn):

剛剛我們已將在暫停的時(shí)候加入到時(shí)間記錄的邏輯里,接下來我們要記錄一個(gè)暫停時(shí)長(zhǎng)。在記錄暫停時(shí)長(zhǎng)之前,我們需要一個(gè)地方給這個(gè)值賦予一個(gè)初始值為 0 。

最好的地方就是在 Timeline 開始的時(shí)候就賦予這個(gè)默認(rèn)值。我們的 PAUSE_TIME 有了初始值之后,我們?cè)趫?zhí)行 resume 的時(shí)候,就可以用 Date.now() - PAUSE_START 就能得到暫停動(dòng)畫到現(xiàn)在的總時(shí)長(zhǎng)。

這里有一個(gè)點(diǎn),需要我們注意的。我們的動(dòng)畫可能會(huì)出現(xiàn)多次暫停,并且多次的續(xù)播。那么這樣的話,如果我們每次都使用這個(gè)公式計(jì)算出新的暫停時(shí)長(zhǎng),然后覆蓋 PAUSE_TIME 的值,其實(shí)是不正確的。

因?yàn)槲覀兊?Timeline 一旦開啟是不會(huì)停止的,時(shí)間一直都在流逝。如果我們每次都只是計(jì)算當(dāng)前的暫停時(shí)長(zhǎng),回退的時(shí)間其實(shí)是不對(duì)的。而正確的方式是,每次暫停時(shí)都需要去疊加上一次暫停過的時(shí)長(zhǎng)。這樣最后回退的時(shí)間才是準(zhǔn)確的。

所以我們賦值給 PAUSE_TIME 的時(shí)候是使用 +=,而不是覆蓋賦值。

最后我們改造好的 Timeline 就是這樣的:

export class Timeline {
 constructor() {
 this[ANIMATIONS] = new Set();
 this[START_TIMES] = new Map();
 }
 start() {
 let startTime = Date.now();
 this[PAUSE_TIME] = 0;
 this[TICK] = () => {
 let now = Date.now();
 for (let animation of this[ANIMATIONS]) {
 let t;

 if (this[START_TIMES].get(animation) < startTime) {
  t = now - startTime - animation.delay - this[PAUSE_TIME];
 } else {
  t = now - this[START_TIMES].get(animation) - animation.delay - this[PAUSE_TIME];
 }

 if (t > animation.duration) {
  this[ANIMATIONS].delete(animation);
  t = animation.duration;
 }
 if (t > 0) animation.run(t);
 }
 this[TICK_HANDLER] = requestAnimationFrame(this[TICK]);
 };
 this[TICK]();
 }
 pause() {
 this[PAUSE_START] = Date.now();
 cancelAnimationFrame(this[TICK_HANDLER]);
 }
 resume() {
 this[PAUSE_TIME] += Date.now() - this[PAUSE_START];
 this[TICK]();
 }
 reset() {}
 add(animation, startTime) {
 if (arguments.length < 2) startTime = Date.now();
 this[ANIMATIONS].add(animation);
 this[START_TIMES].set(animation, startTime);
 }
}

我們運(yùn)行一下代碼看看是否正確:

這樣我們就完成了 Pause 和 Resume 兩個(gè)功能了。

這里我們就實(shí)現(xiàn)了一個(gè)可用的 Timeline 時(shí)間軸,下一篇文章我們重點(diǎn)去加強(qiáng)動(dòng)畫庫的功能。

如果你是一個(gè)開發(fā)者,做一個(gè)個(gè)人博客也是你簡(jiǎn)歷上的一個(gè)亮光點(diǎn)。而如果你有一個(gè)超級(jí)炫酷的博客,那就更加是亮上加亮了,簡(jiǎn)直就閃閃發(fā)光。

主題 Github 地址:https://github.com/auroral-ui/hexo-theme-aurora
主題使用文檔:https://aurora.tridiamond.tech/zh/


到此這篇關(guān)于使用JavaScript 實(shí)現(xiàn)時(shí)間軸與動(dòng)畫效果的示例代碼(前端組件化)的文章就介紹到這了,更多相關(guān)js 實(shí)現(xiàn)時(shí)間軸動(dòng)畫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js實(shí)現(xiàn)將json數(shù)組顯示前臺(tái)table中

    js實(shí)現(xiàn)將json數(shù)組顯示前臺(tái)table中

    本文主要介紹了把JSON數(shù)組顯示在前臺(tái)的table中的方法。具有一定的參考價(jià)值,下面跟著小編一起來看下吧
    2017-01-01
  • Rollup處理并打包JS文件項(xiàng)目實(shí)例代碼

    Rollup處理并打包JS文件項(xiàng)目實(shí)例代碼

    rollup是一款用來es6模塊打包代碼的構(gòu)建工具(支持css和js打包)。這篇文章主要介紹了Rollup處理并打包JS文件項(xiàng)目實(shí)例,需要的朋友可以參考下
    2018-05-05
  • 仿京東快報(bào)向上滾動(dòng)的實(shí)例

    仿京東快報(bào)向上滾動(dòng)的實(shí)例

    下面小編就為大家分享一篇仿京東快報(bào)向上滾動(dòng)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • js生成word中圖片處理方法

    js生成word中圖片處理方法

    下面小編就為大家分享一篇js生成word中圖片處理方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • 必備的JS調(diào)試技巧匯總

    必備的JS調(diào)試技巧匯總

    試想一下:出現(xiàn)了某個(gè)bug,有人用幾分鐘就搞定了,有人用了半天或者一天都找不到原因所在。你愿意當(dāng)前者還是后者呢?想當(dāng)前者的就請(qǐng)好好看完本篇文章吧。文中涉及較多Gif演示動(dòng)畫請(qǐng)注意。
    2016-07-07
  • javascript實(shí)現(xiàn)獲取服務(wù)器時(shí)間

    javascript實(shí)現(xiàn)獲取服務(wù)器時(shí)間

    本文給大家總結(jié)了一下使用javascript來獲取服務(wù)器時(shí)間的幾種方法和思路,十分的簡(jiǎn)單明了,有需要的小伙伴可以參考下
    2015-05-05
  • js get和post請(qǐng)求實(shí)現(xiàn)代碼解析

    js get和post請(qǐng)求實(shí)現(xiàn)代碼解析

    這篇文章主要介紹了js get和post實(shí)現(xiàn)代碼解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • js閉包所用的場(chǎng)合以及優(yōu)缺點(diǎn)分析

    js閉包所用的場(chǎng)合以及優(yōu)缺點(diǎn)分析

    這篇文章主要介紹了js閉包所用的場(chǎng)合以及優(yōu)缺點(diǎn)分析,十分的詳細(xì)使用,有需要的小伙伴可以參考下。
    2015-06-06
  • js判斷橫豎屏及禁止瀏覽器滑動(dòng)條示例

    js判斷橫豎屏及禁止瀏覽器滑動(dòng)條示例

    這篇文章主要介紹了使用js如何判斷橫豎屏及禁止瀏覽器滑動(dòng)條,需要的朋友可以參考下
    2014-04-04
  • Javascript中的Prototype到底是什么

    Javascript中的Prototype到底是什么

    Javascript也是面向?qū)ο蟮恼Z言,但它是一種基于原型Prototype的語言,而不是基于類的語言。接下來通過本文給大家介紹Javascript中的Prototype到底是啥的相關(guān)知識(shí),感興趣的朋友參考下
    2016-02-02

最新評(píng)論

欧美日韩亚洲国产无线码| 亚洲综合色在线免费观看| 亚国产成人精品久久久| 91免费观看国产免费| 天天日天天干天天干天天日| 五月色婷婷综合开心网4438| 中文 成人 在线 视频| 亚洲天堂第一页中文字幕| 欧美日韩v中文在线| 亚洲av第国产精品| 色狠狠av线不卡香蕉一区二区| 人妻在线精品录音叫床| 日本脱亚入欧是指什么| 插逼视频双插洞国产操逼插洞| 不戴胸罩引我诱的隔壁的人妻| tube69日本少妇| 任我爽精品视频在线播放| 精品视频国产在线观看| 美女少妇亚洲精选av| 爆乳骚货内射骚货内射在线| 在线不卡成人黄色精品| 亚洲欧美一区二区三区电影| 最新激情中文字幕视频| 偷拍自拍 中文字幕| 中文字幕在线乱码一区二区| gav成人免费播放| 亚洲精品一区二区三区老狼| 精品区一区二区三区四区人妻| 成人福利视频免费在线| 99国内小视频在现欢看| 欧美在线精品一区二区三区视频| 美女吃鸡巴操逼高潮视频| 日韩少妇人妻精品无码专区| 狠狠嗨日韩综合久久| 3D动漫精品啪啪一区二区下载| 新婚人妻聚会被中出| 51精品视频免费在线观看| 福利视频网久久91| av大全在线播放免费| 中文字幕av男人天堂| 福利片区一区二体验区| 男人的天堂av日韩亚洲| 亚洲成人av一区久久| 成人蜜桃美臀九一一区二区三区| 天堂v男人视频在线观看| 成人精品视频99第一页| 中文字幕人妻av在线观看| 宅男噜噜噜666国产| 大屁股肉感人妻中文字幕在线| 日韩一区二区三区三州| 日韩在线中文字幕色| 国产九色91在线视频| 黑人3p华裔熟女普通话| 成人免费毛片aaaa| 大黑人性xxxxbbbb| 粉嫩小穴流水视频在线观看| 亚洲高清自偷揄拍自拍| 中文字幕一区二 区二三区四区| 精品视频一区二区三区四区五区| 亚洲av第国产精品| 亚洲在线一区二区欧美| 在线观看av2025| 国产在线91观看免费观看| 国产一区二区神马久久| 亚洲变态另类色图天堂网| 国产精品视频欧美一区二区| 40道精品招牌菜特色| 亚洲高清一区二区三区视频在线| 风流唐伯虎电视剧在线观看| 婷婷六月天中文字幕| 亚洲精品福利网站图片| 日韩一区二区三区三州| 国产91精品拍在线观看| 香蕉片在线观看av| 中文字幕之无码色多多| 天天操天天爽天天干| 亚洲欧美色一区二区| 欧美视频不卡一区四区| 传媒在线播放国产精品一区| 日本少妇人妻xxxxx18| 日韩无码国产精品强奸乱伦| 中文字幕在线免费第一页| 久碰精品少妇中文字幕av| 国产欧美日韩在线观看不卡| 亚洲一区久久免费视频| 免费观看污视频网站| 日韩无码国产精品强奸乱伦| 日本xx片在线观看| 黄色成年网站午夜在线观看| 91九色porny蝌蚪国产成人| 亚洲精品ww久久久久久| 欧美精品黑人性xxxx| 337p日本大胆欧美人| 免费十精品十国产网站| 污污小视频91在线观看| 免费无码人妻日韩精品一区二区| 日韩写真福利视频在线观看| 欧美黑人巨大性xxxxx猛交| 亚洲 欧美 自拍 偷拍 在线| 国产伊人免费在线播放| 自拍偷拍 国产资源| 激情人妻校园春色亚洲欧美| 日韩熟女av天堂系列| 国产无遮挡裸体免费直播视频| 色av色婷婷人妻久久久精品高清 | a v欧美一区=区三区| 中文字幕av熟女人妻| 成人免费公开视频无毒| 日本免费视频午夜福利视频| 日本中文字幕一二区视频| 激情国产小视频在线| 亚洲精品高清自拍av| 国产在线91观看免费观看| av大全在线播放免费| 日本五十路熟新垣里子| 天天躁日日躁狠狠躁躁欧美av| 久久亚洲天堂中文对白| 在线不卡成人黄色精品| 国产黄色高清资源在线免费观看| 日韩成人免费电影二区| 日美女屁股黄邑视频| 色婷婷精品大在线观看| 成人蜜桃美臀九一一区二区三区| 国产乱子伦一二三区| 亚洲美女自偷自拍11页| 人妻最新视频在线免费观看| 色哟哟在线网站入口| 99热碰碰热精品a中文| 自拍偷拍亚洲另类色图| 日本高清撒尿pissing| 亚洲av人人澡人人爽人人爱| 人人妻人人爽人人澡人人精品| 国产中文精品在线观看| 精品国产在线手机在线| 国产在线91观看免费观看| 久草免费人妻视频在线| 中文字幕第1页av一天堂网| 偷拍自拍福利视频在线观看| 黄页网视频在线免费观看| 中文字幕1卡1区2区3区| 成人av电影免费版| 青青青爽视频在线播放| 久久艹在线观看视频| 国产精品黄大片在线播放| 日韩欧美中文国产在线| 欧美偷拍自拍色图片| 天天插天天狠天天操| 欧美综合婷婷欧美综合| 适合午夜一个人看的视频| 日韩av有码中文字幕| 亚洲天堂第一页中文字幕| 免费费一级特黄真人片| 少妇被强干到高潮视频在线观看| 亚洲欧美一区二区三区爱爱动图| 熟女国产一区亚洲中文字幕| 国产 在线 免费 精品| 天干天天天色天天日天天射| 亚洲天堂精品久久久| 日本xx片在线观看| 美洲精品一二三产区区别| 天天做天天干天天操天天射| 日韩av免费观看一区| 美女大bxxxx内射| 97人人妻人人澡人人爽人人精品| 美女骚逼日出水来了| 欧洲国产成人精品91铁牛tv| 制丝袜业一区二区三区| 青青青激情在线观看视频| 色av色婷婷人妻久久久精品高清| 在线视频自拍第三页| 天天干夜夜操啊啊啊| 一区二区三区激情在线| 日本少妇的秘密免费视频| 国产精品免费不卡av| 国产日韩精品电影7777| 综合页自拍视频在线播放| 在线观看av2025| 欧美成人综合视频一区二区| 偷青青国产精品青青在线观看| 国产精品熟女久久久久浪潮| 天天日天天敢天天干| 香港一级特黄大片在线播放| 大香蕉伊人国产在线| 亚洲av色香蕉一区二区三区| 久久尻中国美女视频| 93视频一区二区三区| 亚洲蜜臀av一区二区三区九色| 国产一线二线三线的区别在哪| 亚洲蜜臀av一区二区三区九色| 淫秽激情视频免费观看| 999久久久久999| 日韩精品电影亚洲一区| 亚洲精品三级av在线免费观看| 午夜场射精嗯嗯啊啊视频| 国产亚洲四十路五十路| 大鸡巴后入爆操大屁股美女 | 专门看国产熟妇的网站| 自拍偷拍日韩欧美一区二区| 国产亚洲精品欧洲在线观看| 日韩av熟妇在线观看| 伊人情人综合成人久久网小说 | 中文字幕第一页国产在线| 国产激情av网站在线观看| 久久这里只有精品热视频| 自拍偷拍 国产资源| 国产性感美女福利视频| 欧美日韩人妻久久精品高清国产| 日韩二区视频一线天婷婷五| 又色又爽又黄又刺激av网站| 欧美成人小视频在线免费看| 亚洲最大黄了色网站| 午夜精品一区二区三区城中村| 欧美黑人性猛交xxxxⅹooo| 操人妻嗷嗷叫视频一区二区| 国产成人精品亚洲男人的天堂| 久久久久久国产精品| 97资源人妻免费在线视频| 日韩不卡中文在线视频网站| 亚洲欧美精品综合图片小说| 久久三久久三久久三久久| 成人激情文学网人妻| 麻豆精品成人免费视频| 久久三久久三久久三久久| 11久久久久久久久久久| 91人妻精品一区二区久久| 亚洲日本一区二区三区| 91av精品视频在线| 一个人免费在线观看ww视频| 国产精品免费不卡av| 久久精品国产23696| 国产免费av一区二区凹凸四季| 一区二区三区的久久的蜜桃的视频| 国产va精品免费观看| 美女张开两腿让男人桶av| 中文字幕 码 在线视频| 99国内小视频在现欢看| 亚洲伊人久久精品影院一美女洗澡 | 99热99re在线播放| 色爱av一区二区三区| av视网站在线观看| av网址国产在线观看| 日本a级视频老女人| 国产97视频在线精品| 亚洲欧美自拍另类图片| 天堂av在线官网中文| 神马午夜在线观看视频| 天天插天天狠天天操| 欧美爆乳肉感大码在线观看| 国产一级精品综合av| 男生舔女生逼逼视频| 91快播视频在线观看| 免费观看污视频网站| 国产成人精品久久二区91| 99久久久无码国产精品性出奶水| 蜜臀av久久久久久久| 午夜激情精品福利视频| 玩弄人妻熟妇性色av少妇| 免费av岛国天堂网站| 一区二区三区毛片国产一区| 一区二区三区久久中文字幕| 亚洲天堂精品福利成人av| 精品av国产一区二区三区四区 | 国际av大片在线免费观看| 天天日夜夜干天天操| 国产视频一区在线观看| 亚洲欧美综合另类13p| 97色视频在线观看| 91国偷自产一区二区三区精品| 一区二区三区激情在线| 护士特殊服务久久久久久久| 人妻最新视频在线免费观看| 人妻丝袜精品中文字幕| 亚洲av男人天堂久久| 日韩欧美国产一区ab| 日韩三级电影华丽的外出| 久精品人妻一区二区三区| www日韩毛片av| 欧美一区二区三区高清不卡tv| 精品av国产一区二区三区四区 | 亚洲欧美自拍另类图片| 亚洲精品国产在线电影| 国产九色91在线观看精品| 日本一区美女福利视频| 欧美一级视频一区二区| 日韩欧美制服诱惑一区在线| 99久久久无码国产精品性出奶水| 亚洲精品乱码久久久本| 黄色片年轻人在线观看| 中文字幕欧美日韩射射一| www久久久久久久久久久| 日本午夜福利免费视频| 黄色在线观看免费观看在线| 天美传媒mv视频在线观看| 91av精品视频在线| 大鸡八强奸视频在线观看| 精品久久久久久高潮| 天天操天天弄天天射| 免费观看成年人视频在线观看| 欧美精品欧美极品欧美视频| 免费一级黄色av网站| 亚洲va天堂va国产va久| 97精品成人一区二区三区 | 激情图片日韩欧美人妻| 亚洲久久午夜av一区二区| 亚洲熟女久久久36d| 亚洲欧美日韩视频免费观看| av破解版在线观看| 人妻无码色噜噜狠狠狠狠色| 国产午夜亚洲精品麻豆| 天天操夜夜骑日日摸| 国产中文精品在线观看| 99精品亚洲av无码国产另类| 久久午夜夜伦痒痒想咳嗽P| 亚洲另类伦春色综合小| 日本少妇精品免费视频| 亚洲精品久久视频婷婷| 1区2区3区4区视频在线观看| 婷婷久久一区二区字幕网址你懂得| 日日夜夜大香蕉伊人| 青青青青操在线观看免费| 日本美女性生活一级片| 亚洲成人三级在线播放| 欧美成人综合视频一区二区| ka0ri在线视频| 性色蜜臀av一区二区三区| 日本人妻少妇18—xx| 亚洲一区二区三区精品乱码| 在线新三级黄伊人网| 91国产在线视频免费观看| 十八禁在线观看地址免费| 在线观看的黄色免费网站| 国产露脸对白在线观看| 午夜91一区二区三区| 人人妻人人爽人人添夜| 免费观看丰满少妇做受| 亚洲成人av一区在线| 美洲精品一二三产区区别| 肏插流水妹子在线乐播下载| 黑人巨大的吊bdsm| 亚洲另类图片蜜臀av| 国产1区,2区,3区| 97人妻总资源视频| 中英文字幕av一区| 欧美黑人性暴力猛交喷水| 性感美女福利视频网站| 欧美麻豆av在线播放| 日韩人妻丝袜中文字幕| 欧美视频中文一区二区三区| 欧美在线偷拍视频免费看| 国产黄色大片在线免费播放| 久久综合老鸭窝色综合久久| 天天摸天天日天天操| 视频 一区二区在线观看| 久久精品国产亚洲精品166m| 视频一区二区综合精品| 亚洲一区av中文字幕在线观看| 欧美日本aⅴ免费视频| 中文字幕在线乱码一区二区| 丝袜美腿欧美另类 中文字幕| 2022天天干天天操| 中文字幕综合一区二区| 黄色片黄色片wyaa| 男生用鸡操女生视频动漫| 美女福利视频导航网站| 狍和女人的王色毛片| 欧美精品免费aaaaaa| 一区二区熟女人妻视频| 香蕉片在线观看av| 久久免费看少妇高潮完整版| 欧美日韩一区二区电影在线观看 | 亚洲一区二区三区偷拍女厕91| 日本精品一区二区三区在线视频。 | 国产大学生援交正在播放| 欧美日韩中文字幕欧美| 亚洲男人的天堂a在线| 九色porny九色9l自拍视频| 欧美亚洲偷拍自拍色图| 40道精品招牌菜特色| 中文字母永久播放1区2区3区 | 日本性感美女视频网站| 欧美亚洲牲夜夜综合久久| 边摸边做超爽毛片18禁色戒| 一区二区久久成人网| 老司机免费视频网站在线看| 国产普通话插插视频| 亚洲欧美另类自拍偷拍色图| 成人av在线资源网站| 欧美日韩激情啪啪啪| 18禁美女无遮挡免费| 日韩美女精品视频在线观看网站| av久久精品北条麻妃av观看| 色吉吉影音天天干天天操| 骚逼被大屌狂草视频免费看| 国产熟妇一区二区三区av | 天堂中文字幕翔田av| 亚洲精品一区二区三区老狼| 中文字幕1卡1区2区3区| 天天日天天干天天插舔舔| 五十路息与子猛烈交尾视频 | 在线观看的黄色免费网站| 乱亲女秽乱长久久久| 2021最新热播中文字幕| 538精品在线观看视频| 亚洲综合在线视频可播放| 美女 午夜 在线视频| 国产清纯美女al在线| 自拍偷拍,中文字幕| 国产视频一区二区午夜| 欧美一区二区三区乱码在线播放| 亚洲av琪琪男人的天堂| 91精品国产91青青碰| 天天插天天色天天日| 少妇一区二区三区久久久| 久草视频首页在线观看| 天天日天天爽天天爽| 91精品激情五月婷婷在线| 国产aⅴ一线在线观看| 少妇深喉口爆吞精韩国| 欧美怡红院视频在线观看| 国产精品国色综合久久| 91天堂天天日天天操| av在线免费资源站| 亚洲激情,偷拍视频| 啪啪啪啪啪啪啪免费视频| 中文字幕欧美日韩射射一| 亚洲国产成人av在线一区| 亚洲精品三级av在线免费观看| 小穴多水久久精品免费看| 人妻熟女中文字幕aⅴ在线| 久久精品36亚洲精品束缚| 视频二区在线视频观看| 中文字幕免费在线免费| 中文字幕欧美日韩射射一| 青青在线视频性感少妇和隔壁黑丝| 亚洲图片偷拍自拍区| 日本午夜爽爽爽爽爽视频在线观看| 亚洲va天堂va国产va久| 国产性色生活片毛片春晓精品| 91成人精品亚洲国产| 熟女在线视频一区二区三区| eeuss鲁片一区二区三区| 国产白袜脚足J棉袜在线观看| 国产亚洲四十路五十路| 在线播放一区二区三区Av无码| 午夜精品一区二区三区更新| 亚洲最大免费在线观看| 成年人的在线免费视频| 岛国青草视频在线观看| 三上悠亚和黑人665番号| 日本韩国亚洲综合日韩欧美国产| 日日夜夜大香蕉伊人| 中文 成人 在线 视频| 综合激情网激情五月五月婷婷| 国产熟妇一区二区三区av| 久久久噜噜噜久久熟女av| 日日夜夜狠狠干视频| 亚洲福利精品福利精品福利| 深田咏美亚洲一区二区| 日韩欧美一级精品在线观看| 社区自拍揄拍尻屁你懂的| 制丝袜业一区二区三区| 免费在线播放a级片| 国产成人综合一区2区| 久久麻豆亚洲精品av| 一区二区视频在线观看免费观看| 日韩写真福利视频在线观看| 午夜在线观看岛国av,com| 大鸡巴后入爆操大屁股美女| 九一传媒制片厂视频在线免费观看| 女人精品内射国产99| av视网站在线观看| 欧美怡红院视频在线观看| caoporm超碰国产| 成人性爱在线看四区| 97超碰免费在线视频| 日本一区美女福利视频| 蜜臀av久久久久蜜臀av麻豆| 二区中出在线观看老师 | 成熟丰满熟妇高潮xx×xx | 99国产精品窥熟女精品| 端庄人妻堕落挣扎沉沦| 国产精品国色综合久久| av日韩在线观看大全| 91老师蜜桃臀大屁股| 2018最新中文字幕在线观看| 极品丝袜一区二区三区| 国产av国片精品一区二区| 亚洲av男人天堂久久| 亚洲变态另类色图天堂网| 久久这里只有精品热视频| 天天干天天操天天爽天天摸 | 成人色综合中文字幕| 成人动漫大肉棒插进去视频| 亚洲国产美女一区二区三区软件| 偷拍3456eee| 欲乱人妻少妇在线视频裸| 爆乳骚货内射骚货内射在线| 青青青青青青青青青青草青青 | 国产精品一区二区三区蜜臀av| 欧美第一页在线免费观看视频| 久久免费看少妇高潮完整版| 黄网十四区丁香社区激情五月天| 亚洲精品乱码久久久久久密桃明| 国产性生活中老年人视频网站| 日本在线不卡免费视频| 亚洲成人av一区在线| 精品av国产一区二区三区四区| 91人妻精品一区二区久久| 五十路息与子猛烈交尾视频| 美女少妇亚洲精选av| 国产精品三级三级三级| 91天堂精品一区二区| 激情五月婷婷综合色啪| 午夜在线观看一区视频| 中文字幕日韩人妻在线三区| 一级黄片大鸡巴插入美女| 馒头大胆亚洲一区二区| 91成人精品亚洲国产| 欧美成人一二三在线网| 久久这里有免费精品| 亚洲激情偷拍一区二区| 亚洲欧美综合另类13p| 粉嫩av懂色av蜜臀av| 亚洲一区二区三区av网站| 成人H精品动漫在线无码播放| 天堂女人av一区二区| 老司机深夜免费福利视频在线观看| 成人H精品动漫在线无码播放| 亚洲va欧美va人人爽3p| 好吊操视频这里只有精品| 日本av熟女在线视频| 视频久久久久久久人妻| 最新激情中文字幕视频| 国产97视频在线精品| 社区自拍揄拍尻屁你懂的| 国产自拍在线观看成人| 亚洲 中文 自拍 无码| 国产性感美女福利视频| 日韩中文字幕在线播放第二页| 精品视频中文字幕在线播放| 久草视频在线免播放| 日韩精品中文字幕福利| 男女之间激情网午夜在线| 美女张开腿让男生操在线看| 国产精彩福利精品视频| 午夜精品一区二区三区城中村| 亚洲人一区二区中文字幕| 久久三久久三久久三久久| 一区二区三区麻豆福利视频| 国产之丝袜脚在线一区二区三区| 亚洲国产免费av一区二区三区| 最新的中文字幕 亚洲| 亚洲va国产va欧美va在线| 中文字幕 码 在线视频| 日韩成人性色生活片| jul—619中文字幕在线| 2022国产综合在线干| 国产av自拍偷拍盛宴| 天天躁日日躁狠狠躁躁欧美av| 无忧传媒在线观看视频| av天堂中文字幕最新| avjpm亚洲伊人久久| 亚洲av自拍天堂网| 播放日本一区二区三区电影| 日韩美女福利视频网| 久久久久久9999久久久久| 国产在线一区二区三区麻酥酥| 粉嫩av懂色av蜜臀av| 老鸭窝在线观看一区| 日韩精品中文字幕福利| 自拍偷拍亚洲精品第2页| 鸡巴操逼一级黄色气| 啊慢点鸡巴太大了啊舒服视频| 日韩亚国产欧美三级涩爱| 免费69视频在线看| 91亚洲国产成人精品性色| brazzers欧熟精品系列| 国产成人一区二区三区电影网站 | 999九九久久久精品| 成人24小时免费视频| 亚洲一级美女啪啪啪| 又黄又刺激的午夜小视频| 亚洲综合在线观看免费| 国产精品系列在线观看一区二区| 日韩熟女av天堂系列| 国产亚洲欧美45p| 在线新三级黄伊人网| 91www一区二区三区| 77久久久久国产精产品| 五月天久久激情视频| 一个人免费在线观看ww视频| 亚洲最大免费在线观看| 日本少妇在线视频大香蕉在线观看 | 午夜在线观看岛国av,com| 18禁精品网站久久| 青青青青在线视频免费观看| 精彩视频99免费在线| 免费在线播放a级片| 欧美精品国产综合久久| 2017亚洲男人天堂| 亚洲欧美国产综合777| 男人操女人的逼免费视频| 天天操夜夜骑日日摸| 极品丝袜一区二区三区| av中文字幕网址在线| 2012中文字幕在线高清| 亚洲av日韩精品久久久| 啪啪啪啪啪啪啪免费视频| 专门看国产熟妇的网站| 中文 成人 在线 视频| 日本在线一区二区不卡视频| 噜噜色噜噜噜久色超碰| 一本久久精品一区二区| 最新中文字幕乱码在线| 国产高清精品一区二区三区| 人妻少妇av在线观看| 中文字幕综合一区二区| 欧美亚洲中文字幕一区二区三区| 一区二区三区国产精选在线播放| 中文字母永久播放1区2区3区| 一区二区免费高清黄色视频| 99国内小视频在现欢看| 欧美激情精品在线观看| 久久精品国产23696| 沙月文乃人妻侵犯中文字幕在线| lutube在线成人免费看| 老师让我插进去69AV| 国产夫妻视频在线观看免费| 一区二区视频视频视频| 天干天天天色天天日天天射| 欧美另类一区二区视频| 久久久久久久久久一区二区三区 | 欧美激情电影免费在线| 国产精品一区二区久久久av| AV天堂一区二区免费试看| 欧美性感尤物人妻在线免费看| 国产精品人妻66p| 欧美黑人性暴力猛交喷水| 中文字幕高清在线免费播放| 无码国产精品一区二区高潮久久4| 极品粉嫩小泬白浆20p主播| 3344免费偷拍视频| 国产一区二区视频观看| 亚洲天堂av最新网址| 欧美亚洲少妇福利视频| 国产男女视频在线播放| 黄色视频在线观看高清无码| 在线国产中文字幕视频| 婷婷午夜国产精品久久久| 午夜激情高清在线观看| 玖玖一区二区在线观看| 人人在线视频一区二区| 国产亚洲精品欧洲在线观看| 久久精品国产23696| 绝顶痉挛大潮喷高潮无码| 黑人巨大精品欧美视频| 91破解版永久免费| 一区二区三区四区五区性感视频| 1000小视频在线| av中文字幕电影在线看| 三级等保密码要求条款| 亚洲高清自偷揄拍自拍| 大陆精品一区二区三区久久| 一区二区三区久久中文字幕| 国产不卡av在线免费| 国产亚洲精品品视频在线| 亚洲变态另类色图天堂网| 清纯美女在线观看国产| 久青青草视频手机在线免费观看 | 水蜜桃一区二区三区在线观看视频| 国产精品3p和黑人大战| 国产一区二区欧美三区| 大香蕉伊人国产在线| 97人人模人人爽人人喊| 丝袜国产专区在线观看| 很黄很污很色的午夜网站在线观看 | 北条麻妃高跟丝袜啪啪| 天天射,天天操,天天说| 国产在线一区二区三区麻酥酥| av在线资源中文字幕| 免费手机黄页网址大全| 日韩特级黄片高清在线看| 亚洲激情av一区二区| 亚洲国产精品黑丝美女| 亚洲欧美国产麻豆综合| 无忧传媒在线观看视频| 91在线免费观看成人| 天天做天天干天天舔| 大屁股肉感人妻中文字幕在线| 青青热久免费精品视频在线观看 | 五色婷婷综合狠狠爱| 丝袜美腿欧美另类 中文字幕| 一区国内二区日韩三区欧美| 亚洲欧美久久久久久久久| 久久久久久九九99精品| 亚洲天堂av最新网址| 2021国产一区二区| 精品一区二区三区三区色爱| 一个色综合男人天堂| 女生自摸在线观看一区二区三区| 日本三极片中文字幕| 国产综合视频在线看片| 亚洲欧美一区二区三区爱爱动图| 中文字幕欧美日韩射射一| 成年人黄色片免费网站| 青青草精品在线视频观看| 女人精品内射国产99| 综合国产成人在线观看| 国内精品在线播放第一页| 青青草原网站在线观看| 天天草天天色天天干| 人人妻人人澡人人爽人人dvl| 亚洲伊人av天堂有码在线| 国产品国产三级国产普通话三级| 成人午夜电影在线观看 久久| 鸡巴操逼一级黄色气| 亚洲色偷偷综合亚洲AV伊人| 激情五月婷婷综合色啪| gogo国模私拍视频| 在线观看的a站 最新| 内射久久久久综合网| 成人H精品动漫在线无码播放| 2012中文字幕在线高清| 亚洲天堂第一页中文字幕| 久久久久久cao我的性感人妻 | 精品欧美一区二区vr在线观看| 中文字幕高清免费在线人妻| 天天色天天爱天天爽| 日韩激情文学在线视频| 成人影片高清在线观看| 大陆av手机在线观看| 社区自拍揄拍尻屁你懂的| 东京热男人的av天堂| 夜夜嗨av蜜臀av| 亚洲成人三级在线播放| 少妇系列一区二区三区视频| 91在线免费观看成人| 毛片一级完整版免费| 日韩欧美制服诱惑一区在线| 国产日本欧美亚洲精品视| 98视频精品在线观看| 老司机在线精品福利视频| 中文字幕在线视频一区二区三区| wwwxxx一级黄色片| 免费大片在线观看视频网站| av乱码一区二区三区| 久久热久久视频在线观看| 老师让我插进去69AV| 2021久久免费视频| 久久国产精品精品美女| caoporn蜜桃视频| 青青草人人妻人人妻| 一区二区三区四区中文| 一区二区三区综合视频| 午夜91一区二区三区| 边摸边做超爽毛片18禁色戒| 国产美女一区在线观看| 亚洲综合在线视频可播放| 欧美国品一二三产区区别| 综合国产成人在线观看| 懂色av蜜桃a v| 中文字幕一区二区三区蜜月 | 青青在线视频性感少妇和隔壁黑丝| 中英文字幕av一区| 亚洲一区二区人妻av| 最近中文字幕国产在线| 亚洲福利精品福利精品福利| 大胸性感美女羞爽操逼毛片| 国产麻豆国语对白露脸剧情| 久草视频在线一区二区三区资源站| 香蕉91一区二区三区| 日本黄在免费看视频| 色吉吉影音天天干天天操| 色婷婷综合激情五月免费观看| okirakuhuhu在线观看| 精彩视频99免费在线| www骚国产精品视频| 久久www免费人成一看片| 日韩近亲视频在线观看| 青青草亚洲国产精品视频| 国产三级片久久久久久久| 亚洲中文字字幕乱码| 我想看操逼黄色大片| 亚洲Av无码国产综合色区| 日韩欧美国产一区不卡| 亚洲人妻国产精品综合| 精品老妇女久久9g国产| 在线观看国产网站资源| 狠狠躁夜夜躁人人爽天天天天97| 人妻少妇亚洲精品中文字幕| 日本三极片视频网站观看| 国产精品人久久久久久| 亚洲国产欧美国产综合在线| 综合国产成人在线观看| 国产一区二区久久久裸臀| 88成人免费av网站| 93精品视频在线观看| 91国内精品久久久久精品一| 免费观看成年人视频在线观看| 亚洲成a人片777777| 亚洲日本一区二区久久久精品| 9l人妻人人爽人人爽| 亚洲精品无码久久久久不卡| 超碰97人人澡人人| 最新国产亚洲精品中文在线| 国产麻豆91在线视频| 国产日本精品久久久久久久| 日日夜夜狠狠干视频| 动漫黑丝美女的鸡巴| 丰满的继坶3中文在线观看| 免费成人va在线观看| 93精品视频在线观看| 国产成人午夜精品福利| 国产精品黄色的av| 91精品综合久久久久3d动漫| 亚洲 欧美 自拍 偷拍 在线| 日噜噜噜夜夜噜噜噜天天噜噜噜| 国产91嫩草久久成人在线视频| 4个黑人操素人视频网站精品91| 91精品激情五月婷婷在线| 亚洲视频乱码在线观看| 日本精品视频不卡一二三| 国产日韩欧美视频在线导航 | 亚洲av在线观看尤物| 最新的中文字幕 亚洲| 喷水视频在线观看这里只有精品| 538精品在线观看视频| 成熟熟女国产精品一区| 国产揄拍高清国内精品对白| 国产欧美日韩第三页| 精品国产午夜视频一区二区| 又粗又硬又猛又黄免费30| 免费看高清av的网站| 日本黄在免费看视频| 自拍偷区二区三区麻豆| 九九视频在线精品播放| 国产成人精品午夜福利训2021| 偷拍自拍亚洲美腿丝袜| 久久这里只有精品热视频 | 成年女人免费播放视频| 欧美在线精品一区二区三区视频 | 黄片大全在线观看观看| 久久久久久久亚洲午夜综合福利| 天天日天天干天天爱| 国产黄色a级三级三级三级| 天天操天天干天天日狠狠插| 又大又湿又爽又紧A视频| 亚洲一级av大片免费观看| 啪啪啪18禁一区二区三区| 美女张开腿让男生操在线看| 91麻豆精品秘密入口在线观看| 一区二区久久成人网| 精品av久久久久久久| 亚洲av琪琪男人的天堂| 国产成人精品av网站| 中文字幕一区二区三区人妻大片| 亚洲高清视频在线不卡| 亚洲av午夜免费观看| 免费成人va在线观看| 可以免费看的www视频你懂的| 一区二区三区四区视频| 六月婷婷激情一区二区三区| 老司机你懂得福利视频| 一级黄色片夫妻性生活| 欧美黑人巨大性xxxxx猛交| 真实国产乱子伦一区二区| 黄色视频在线观看高清无码 | 国产露脸对白在线观看| 97人妻无码AV碰碰视频| 青青青青青操视频在线观看| 人妻久久久精品69系列| 老师让我插进去69AV| 国产视频一区二区午夜| 日韩精品中文字幕福利| 激情伦理欧美日韩中文字幕| 2021年国产精品自拍| jiujiure精品视频在线| 久久精品国产亚洲精品166m| 亚洲综合在线视频可播放| 午夜美女福利小视频| 大肉大捧一进一出好爽在线视频| 粗大的内捧猛烈进出爽大牛汉子| 亚洲专区激情在线观看视频| 国产自拍黄片在线观看| 成人18禁网站在线播放| 亚洲精品麻豆免费在线观看 | 天天做天天干天天舔| 色哟哟在线网站入口| 亚洲人妻av毛片在线| 黄色视频成年人免费观看| 成年人的在线免费视频| 国产实拍勾搭女技师av在线| 天天日天天添天天爽| 精品首页在线观看视频| 日韩av有码一区二区三区4| 五月激情婷婷久久综合网| 免费男阳茎伸入女阳道视频| 亚洲综合自拍视频一区| 日韩精品电影亚洲一区| 国产丰满熟女成人视频| 激情国产小视频在线| 三上悠亚和黑人665番号| 嫩草aⅴ一区二区三区| 欧美日本aⅴ免费视频| 日本人妻精品久久久久久| 欧美80老妇人性视频| 直接能看的国产av| 日日操夜夜撸天天干| av一区二区三区人妻| av日韩在线观看大全| 午夜精品久久久久麻豆影视| 天天操夜夜操天天操天天操| 国产激情av网站在线观看| 18禁污污污app下载| 国产aⅴ一线在线观看| 欧美中国日韩久久精品| 男人的天堂av日韩亚洲| 亚洲人妻av毛片在线| 午夜在线观看岛国av,com| 熟女人妻在线观看视频| 97国产在线av精品| aiss午夜免费视频| 98精产国品一二三产区区别| 97a片免费在线观看| 91天堂精品一区二区| 国产精品久久久久久美女校花| 搡老妇人老女人老熟女| 春色激情网欧美成人| 大胸性感美女羞爽操逼毛片| av一本二本在线观看| 久久久久久久99精品| 最后99天全集在线观看| 国产普通话插插视频| 免费黄高清无码国产| 又粗又硬又猛又爽又黄的| 欧美亚洲少妇福利视频| 色哟哟在线网站入口| 国产黄色大片在线免费播放| 欧美另类z0z变态| 黄网十四区丁香社区激情五月天 | 日本一区二区三区免费小视频| 美女吃鸡巴操逼高潮视频| 91超碰青青中文字幕| 狍和女人的王色毛片| 特一级特级黄色网片| 国产精品伦理片一区二区| av在线观看网址av| 中文字幕av第1页中文字幕| 2020中文字幕在线播放| 亚洲熟女女同志女同| 99re6热在线精品| 黄色的网站在线免费看| 人妻熟女在线一区二区| 超鹏97历史在线观看| 好男人视频在线免费观看网站| yy96视频在线观看| 日韩熟女系列一区二区三区| 亚洲成a人片777777| 深田咏美亚洲一区二区| 国产自拍黄片在线观看| 中文字幕一区二区三区人妻大片| 欧美老妇精品另类不卡片| 一个色综合男人天堂| 欧美va亚洲va天堂va| 天干天天天色天天日天天射| 国产乱弄免费视频观看| 青青草成人福利电影| 不卡日韩av在线观看| 福利视频一区二区三区筱慧| 国产麻豆乱子伦午夜视频观看| 亚洲人妻视频在线网| 无码精品一区二区三区人 | 人妻av无码专区久久绿巨人| 欧美一区二区三区乱码在线播放| 中文字幕日韩无敌亚洲精品| 国产综合高清在线观看| 亚洲成人激情视频免费观看了| 婷婷色国产黑丝少妇勾搭AV| 黄色av网站免费在线| 亚洲成人情色电影在线观看| 日本一道二三区视频久久| av中文字幕在线观看第三页| jiujiure精品视频在线| 欧洲亚洲欧美日韩综合| 人妻少妇亚洲精品中文字幕| 国产精品一区二区av国| 亚洲人成精品久久久久久久| 成人av亚洲一区二区| 最新的中文字幕 亚洲| 天天日天天透天天操| 熟女少妇激情五十路| 91九色国产熟女一区二区| 天天综合天天综合天天网| 天天干天天啪天天舔| 黄片大全在线观看观看| 久久久91蜜桃精品ad| 日韩精品中文字幕在线| 午夜精品福利91av| 我想看操逼黄色大片| 久久麻豆亚洲精品av| 亚洲福利精品福利精品福利| 啪啪啪啪啪啪啪啪av| 男生舔女生逼逼的视频| av资源中文字幕在线观看| 中文字幕熟女人妻久久久| 国产又粗又猛又爽又黄的视频在线| 国产大学生援交正在播放| 天天操天天弄天天射| 新婚人妻聚会被中出| 五十路息与子猛烈交尾视频| 久久www免费人成一看片| 欧美国品一二三产区区别| 91人妻精品久久久久久久网站| 日韩精品电影亚洲一区| 亚洲国产精品久久久久久6| 97色视频在线观看| sspd152中文字幕在线| 最新国产亚洲精品中文在线| 国产揄拍高清国内精品对白| 日韩一区二区三区三州| 中文字幕高清资源站| 4个黑人操素人视频网站精品91| 欧美偷拍自拍色图片| 国产自拍在线观看成人| 男人的天堂av日韩亚洲| 女同互舔一区二区三区| av大全在线播放免费| 青青草成人福利电影| 999久久久久999| 精品成人啪啪18免费蜜臀| 2021天天色天天干| av完全免费在线观看av| 亚洲激情,偷拍视频| 无码日韩人妻精品久久| 久草视频首页在线观看| 国产高清97在线观看视频| 中出中文字幕在线观看| 一区二区三区av高清免费| 日韩欧美一级黄片亚洲| 91欧美在线免费观看| 国产精品自拍在线视频| 国产精选一区在线播放| 综合激情网激情五月天| 久久久久久性虐视频| 久久久超爽一二三av| 很黄很污很色的午夜网站在线观看 | 福利视频网久久91| 中文字幕av熟女人妻| 91啪国自产中文字幕在线| 啊啊啊想要被插进去视频| 女警官打开双腿沦为性奴| 亚洲成人午夜电影在线观看| 女同互舔一区二区三区| 久久美欧人妻少妇一区二区三区| 一级黄色片夫妻性生活| 国产无遮挡裸体免费直播视频| 99久久中文字幕一本人| 久久久久只精品国产三级| 久久久久久久久久久久久97| 人妻凌辱欧美丰满熟妇| jiujiure精品视频在线| 欧美性受xx黑人性猛交| 成人性黑人一级av| rct470中文字幕在线| 97精品成人一区二区三区 | 欧美爆乳肉感大码在线观看 | 日韩一区二区电国产精品| 在线亚洲天堂色播av电影| 日本中文字幕一二区视频| 粉嫩小穴流水视频在线观看| 在线可以看的视频你懂的| 精品人妻伦一二三区久| 六月婷婷激情一区二区三区| 美女少妇亚洲精选av| 不卡一区一区三区在线| 国产精品精品精品999| 欧美地区一二三专区| 欧美精品免费aaaaaa| 国产老熟女伦老熟妇ⅹ| 一区二区麻豆传媒黄片| 日韩美女精品视频在线观看网站| 91人妻精品一区二区久久| 性感美女福利视频网站| 又粗又硬又猛又黄免费30| 欧美精品激情在线最新观看视频| 欧美黑人性猛交xxxxⅹooo| av网站色偷偷婷婷网男人的天堂| 亚洲熟女久久久36d| 男生用鸡操女生视频动漫| 中文字幕人妻av在线观看| 一色桃子久久精品亚洲| 中文字幕人妻被公上司喝醉在线| 日本a级视频老女人| 欧美精品 日韩国产| 男大肉棒猛烈插女免费视频| 久久热久久视频在线观看| 欧美久久久久久三级网| 青青草原网站在线观看| ka0ri在线视频| 2017亚洲男人天堂| 3344免费偷拍视频| 精品人妻每日一部精品| 人人妻人人爱人人草| 亚洲一区二区人妻av| 又色又爽又黄的美女裸体| 成人av天堂丝袜在线观看| 欧美亚洲少妇福利视频| 国产免费av一区二区凹凸四季| 5528327男人天堂| 大香蕉大香蕉在线有码 av| 亚洲精品欧美日韩在线播放 | 精品一区二区三四区| 伊人精品福利综合导航| 国产自拍在线观看成人| 都市家庭人妻激情自拍视频| 亚洲欧美一区二区三区电影| 和邻居少妇愉情中文字幕| 天堂女人av一区二区| 99久久99一区二区三区| 日本人竟这样玩学生妹| 亚洲 图片 欧美 图片| 91精品国产高清自在线看香蕉网| 综合一区二区三区蜜臀| 色婷婷六月亚洲综合香蕉| 日本性感美女视频网站| 国产女人被做到高潮免费视频 | 99久久中文字幕一本人| 五色婷婷综合狠狠爱| av中文字幕国产在线观看| 久久久久五月天丁香社区| 国产精品黄片免费在线观看| 综合国产成人在线观看| 亚洲公开视频在线观看| 国产日韩欧美美利坚蜜臀懂色| 日本少妇在线视频大香蕉在线观看| 久久免费看少妇高潮完整版| 80电影天堂网官网| 欧美精品资源在线观看| 午夜精品一区二区三区城中村| 午夜毛片不卡在线看| 日韩av有码一区二区三区4| 三级黄色亚洲成人av| 亚洲中文精品人人免费| 人妻少妇亚洲一区二区| 国产精品亚洲а∨天堂免| 热思思国产99re| 伊人成人在线综合网| 久久久久久cao我的性感人妻| 啊啊好慢点插舔我逼啊啊啊视频| 熟女91pooyn熟女| 五十路息与子猛烈交尾视频| 91综合久久亚洲综合| 中文字幕av男人天堂| 91免费福利网91麻豆国产精品| 亚洲一区久久免费视频| 亚洲美女高潮喷浆视频| 自拍偷拍亚洲欧美在线视频| 亚洲一区二区激情在线| 98视频精品在线观看| 亚洲伊人色一综合网| 日本精品视频不卡一二三| 98精产国品一二三产区区别| 亚洲免费视频欧洲免费视频| 欧美日韩一级黄片免费观看| 精品一区二区三四区| 亚洲欧美激情人妻偷拍| 日韩av有码一区二区三区4| 91国产在线视频免费观看| 狠狠操操操操操操操操操| 久草福利电影在线观看| 青草亚洲视频在线观看| 红杏久久av人妻一区| 综合国产成人在线观看| 亚洲黄色av网站免费播放| 91成人精品亚洲国产| 一区二区三区美女毛片| 天天夜天天日天天日| 亚洲狠狠婷婷综合久久app| 97色视频在线观看| 男女第一次视频在线观看| 美女福利视频网址导航| 视频久久久久久久人妻| caoporm超碰国产| 日韩特级黄片高清在线看| 51国产偷自视频在线播放| 精品一区二区三四区| 粉嫩欧美美人妻小视频| 婷婷激情四射在线观看视频| 黄色片黄色片wyaa| 中文字幕人妻一区二区视频| 亚洲 自拍 色综合图| 成熟丰满熟妇高潮xx×xx | 在线播放一区二区三区Av无码| 国产精品日韩欧美一区二区| 国产精品自拍视频大全| 国产熟妇一区二区三区av| 自拍偷拍 国产资源| 亚洲国产40页第21页| 最新91精品视频在线 | 91九色国产熟女一区二区| 韩国一级特黄大片做受| 欧美 亚洲 另类综合| 成人免费毛片aaaa| 综合激情网激情五月天| 18禁美女无遮挡免费| 亚洲av无女神免非久久| 久久这里只有精品热视频| 亚洲熟女久久久36d| 男人和女人激情视频| 成人福利视频免费在线| 一色桃子人妻一区二区三区| 激情啪啪啪啪一区二区三区| 91精品国产黑色丝袜| av破解版在线观看| 久草极品美女视频在线观看| 欧美亚洲自偷自拍 在线| 亚洲美女高潮喷浆视频| 欧美一级片免费在线成人观看 | 人妻少妇亚洲一区二区| 日韩一区二区电国产精品| 91大屁股国产一区二区| 最新国产精品网址在线观看| 日本熟妇色熟妇在线观看| av在线免费中文字幕| 91精品国产麻豆国产| 久久这里有免费精品| 99精品免费久久久久久久久a| 亚洲欧美自拍另类图片| 国产性感美女福利视频| 久久综合老鸭窝色综合久久| 免费在线看的黄网站| 自拍偷拍,中文字幕| av老司机精品在线观看| 久草视频首页在线观看| 午夜dv内射一区区| 伊人成人在线综合网| 欧美日韩在线精品一区二区三| 免费手机黄页网址大全| 在线免费观看亚洲精品电影| 91麻豆精品秘密入口在线观看| 中文字幕视频一区二区在线观看| av一区二区三区人妻| 最新国产精品拍在线观看| 亚洲av男人天堂久久| 成人亚洲国产综合精品| 国产janese在线播放| 大香蕉福利在线观看| 老司机99精品视频在线观看| 亚洲一区二区三区av网站| 亚洲欧美人精品高清| 色综合色综合色综合色| 色噜噜噜噜18禁止观看| 天天日天天舔天天射进去| 亚洲av色香蕉一区二区三区| 91精品国产观看免费| 日本www中文字幕| 18禁免费av网站| 在线免费观看99视频| 男人的天堂一区二区在线观看| okirakuhuhu在线观看| 又粗又硬又猛又黄免费30| 黄片色呦呦视频免费看| 东京热男人的av天堂| 欧美 亚洲 另类综合| av俺也去在线播放| 亚洲中文精品字幕在线观看| 亚洲图片偷拍自拍区| 亚洲一级 片内射视正片| 精品国产亚洲av一淫| 在线免费观看靠比视频的网站| 亚洲乱码中文字幕在线| 好男人视频在线免费观看网站| 久久精品国产999| 66久久久久久久久久久| 五十路丰满人妻熟妇| 日本精品美女在线观看| 自拍偷区二区三区麻豆| 粉嫩av蜜乳av蜜臀| 欧美视频一区免费在线| 粉嫩av蜜乳av蜜臀| 亚洲成人免费看电影| 伊人情人综合成人久久网小说| 色秀欧美视频第一页| 性生活第二下硬不起来| av天堂中文字幕最新| 桃色视频在线观看一区二区| 9色在线视频免费观看| 国产美女午夜福利久久| 欧美日本在线视频一区| 100%美女蜜桃视频| 天天躁日日躁狠狠躁躁欧美av| 天美传媒mv视频在线观看| 天天日天天爽天天干| 日韩av免费观看一区| av黄色成人在线观看| av森泽佳奈在线观看| 日本一本午夜在线播放| 日本丰满熟妇BBXBBXHD| 亚洲中文字幕校园春色| a v欧美一区=区三区| 国产精品成久久久久三级蜜臀av| 四虎永久在线精品免费区二区| 韩国亚洲欧美超一级在线播放视频| 青青青青青免费视频| 91国产资源在线视频| 69精品视频一区二区在线观看| 国产夫妻视频在线观看免费| 国产一级麻豆精品免费| 免费人成黄页网站在线观看国产| 四川乱子伦视频国产vip| 久久精品国产23696| 亚洲va国产va欧美va在线| 97青青青手机在线视频| 姐姐的朋友2在线观看中文字幕| 青娱乐在线免费视频盛宴| 欧美在线一二三视频| 国产janese在线播放| 美女福利视频导航网站| 国产又粗又硬又大视频| 硬鸡巴动态操女人逼视频| 国产第一美女一区二区三区四区| 5528327男人天堂| 色婷婷久久久久swag精品| 天堂中文字幕翔田av| 特级无码毛片免费视频播放 | 午夜在线观看一区视频| 伊拉克及约旦宣布关闭领空| 人人妻人人澡人人爽人人dvl| 久久机热/这里只有| 成人亚洲国产综合精品| 午夜91一区二区三区| 天天躁日日躁狠狠躁av麻豆| 久久精品亚洲国产av香蕉| 欧美成人综合色在线噜噜| 色伦色伦777国产精品| 久久精品美女免费视频| 毛片一级完整版免费| 在线观看的黄色免费网站| 亚洲一区二区久久久人妻| 91精品资源免费观看| 青青青视频自偷自拍38碰| 欧美性受xx黑人性猛交| 美女在线观看日本亚洲一区| 亚洲另类伦春色综合小| gogo国模私拍视频| 国产久久久精品毛片| 国产97视频在线精品| 青青青青青青草国产| 亚洲变态另类色图天堂网| 精品av国产一区二区三区四区| 午夜久久久久久久99| 天堂av中文在线最新版| 懂色av蜜桃a v| 丝袜长腿第一页在线| 好太好爽好想要免费| okirakuhuhu在线观看| 任你操任你干精品在线视频| 91色老99久久九九爱精品| 国产使劲操在线播放| 国产精品3p和黑人大战| 久久农村老妇乱69系列| 中文字幕在线一区精品| 在线免费观看靠比视频的网站| 精品91高清在线观看| 91久久精品色伊人6882| 91国产资源在线视频| 国产午夜无码福利在线看| 久久这里只有精品热视频 | av在线观看网址av| 国产成人精品久久二区91| 66久久久久久久久久久| 国产综合精品久久久久蜜臀| ka0ri在线视频| 精品久久婷婷免费视频| 亚洲高清免费在线观看视频| 91九色porny国产在线| 欧美老妇精品另类不卡片| 亚洲熟妇无码一区二区三区| 人人在线视频一区二区| 毛片av在线免费看| 一区二区三区的久久的蜜桃的视频 | 曰本无码人妻丰满熟妇啪啪| 综合激情网激情五月天| 欧美怡红院视频在线观看| 亚洲视频乱码在线观看| 婷婷色国产黑丝少妇勾搭AV| 国产精品自拍在线视频| 久草视频在线一区二区三区资源站| 强行扒开双腿猛烈进入免费版| 92福利视频午夜1000看| 福利一二三在线视频观看| 亚洲欧美一卡二卡三卡| 午夜在线观看一区视频| 成年人黄视频在线观看| 少妇一区二区三区久久久| 久久久久久久久久久免费女人| 久久久噜噜噜久久熟女av| 国产精品一区二区三区蜜臀av| 在线免费观看亚洲精品电影| 婷婷综合蜜桃av在线| 人妻激情图片视频小说| 欧美男人大鸡吧插女人视频| 老司机在线精品福利视频| 99一区二区在线观看| 亚洲天堂精品久久久| 日本脱亚入欧是指什么| 黄色成人在线中文字幕| 999久久久久999| 任你操视频免费在线观看| 91国内视频在线观看| 大香蕉福利在线观看| 久久久久久久久久性潮| 亚洲护士一区二区三区| 女人精品内射国产99| 亚洲午夜伦理视频在线| 美女在线观看日本亚洲一区| 人人妻人人澡欧美91精品| 99热这里只有精品中文| 91精品国产91青青碰| 99精品久久久久久久91蜜桃| 亚洲 人妻 激情 中文| 日日操综合成人av| 日本丰满熟妇BBXBBXHD| 亚洲国产欧美一区二区三区久久| 亚洲综合乱码一区二区| 国产+亚洲+欧美+另类| 午夜大尺度无码福利视频| 伊人成人在线综合网| 国产一区成人在线观看视频| av久久精品北条麻妃av观看 | 亚洲成a人片777777| 国语对白xxxx乱大交| 激情人妻校园春色亚洲欧美 | av中文字幕国产在线观看| 国产chinesehd精品麻豆| 99热久久这里只有精品8| 亚洲最大黄了色网站| avjpm亚洲伊人久久| 高清一区二区欧美系列| 开心 色 六月 婷婷| 久久99久久99精品影院| 成人午夜电影在线观看 久久| 黄色片黄色片wyaa| 五十路丰满人妻熟妇| 国产精品久久久久久久久福交| 日韩精品啪啪视频一道免费| 日韩午夜福利精品试看| 亚洲青青操骚货在线视频| 女生被男生插的视频网站| av老司机亚洲一区二区| 99精品一区二区三区的区| 国产在线一区二区三区麻酥酥 | 亚洲一区二区激情在线| 97人妻总资源视频| 亚洲精品国产久久久久久| 国产密臀av一区二区三| 啊慢点鸡巴太大了啊舒服视频| 亚洲av一妻不如妾| 91社福利《在线观看| 精品久久婷婷免费视频| 少妇一区二区三区久久久| 99热久久这里只有精品| 中文字幕人妻三级在线观看| 成年女人免费播放视频| 成人国产影院在线观看| 激情小视频国产在线| 大尺度激情四射网站| 精品国产亚洲av一淫| aaa久久久久久久久| 888亚洲欧美国产va在线播放| 亚洲一区二区激情在线| 伊人成人综合开心网| 日韩精品中文字幕在线| 最新91精品视频在线| 98视频精品在线观看| 亚洲国产精品久久久久久6| 男生舔女生逼逼视频| 中文字幕日本人妻中出| 真实国模和老外性视频| 天天日天天爽天天干| 午夜极品美女福利视频| 高潮喷水在线视频观看| 日韩欧美中文国产在线| 亚洲综合另类精品小说| 天天日天天摸天天爱| 精品久久久久久久久久中文蒉| 欧美精品 日韩国产| 国产成人自拍视频在线免费观看| 日本三极片视频网站观看| 熟女视频一区,二区,三区| 大鸡吧插入女阴道黄色片| 欧美亚洲国产成人免费在线 | 红桃av成人在线观看| 青草久久视频在线观看| 久久精品国产23696| 视频二区在线视频观看| 熟女国产一区亚洲中文字幕| 中文字幕视频一区二区在线观看| 男女啪啪视频免费在线观看| 中文字幕一区二区人妻电影冢本| 在线可以看的视频你懂的| xxx日本hd高清| 姐姐的朋友2在线观看中文字幕| 亚洲精品中文字幕下载| 国产精品视频欧美一区二区| 亚洲1069综合男同| 91精品免费久久久久久| 日韩精品电影亚洲一区| 人妻3p真实偷拍一二区| 顶级尤物粉嫩小尤物网站| 亚洲1区2区3区精华液| 久草视频在线免播放| 在线新三级黄伊人网| 亚洲福利精品福利精品福利| 97国产精品97久久| 中文字幕av熟女人妻| 人妻凌辱欧美丰满熟妇| 天天日天天鲁天天操| 97人妻夜夜爽二区欧美极品| 国产熟妇一区二区三区av| 521精品视频在线观看| nagger可以指黑人吗| 欧美精品一二三视频| 99视频精品全部15| 人人超碰国字幕观看97| 无忧传媒在线观看视频| 成年女人免费播放视频| 五十路在线观看完整版| 日韩精品激情在线观看| 天天摸天天亲天天舔天天操天天爽| 日韩加勒比东京热二区| 亚洲av男人天堂久久| 美女福利写真在线观看视频| 综合色区亚洲熟妇shxstz| 93视频一区二区三区| 岛国黄色大片在线观看| 免费男阳茎伸入女阳道视频 | 欧美视频中文一区二区三区| 白白操白白色在线免费视频| 亚洲激情av一区二区| 337p日本大胆欧美人| 国产精品国产三级国产精东 | 日韩一个色综合导航| 极品粉嫩小泬白浆20p主播| 日韩三级黄色片网站| 动漫黑丝美女的鸡巴| 在线观看一区二区三级| 欧美麻豆av在线播放| 亚洲高清国产一区二区三区| 日韩中文字幕福利av| 亚洲图片偷拍自拍区| 日本一二三区不卡无| 四川乱子伦视频国产vip| 亚洲av日韩高清hd| 天天色天天操天天透| 最后99天全集在线观看| 福利国产视频在线观看| 91精品国产高清自在线看香蕉网| 超碰97免费人妻麻豆| 亚洲午夜精品小视频| 国产精品久久综合久久| 九色视频在线观看免费| 一色桃子人妻一区二区三区| 成人激情文学网人妻| 亚洲欧美激情人妻偷拍| 天天干天天操天天玩天天射 | 久草视频在线一区二区三区资源站| 欧美日本在线观看一区二区| 欧美另类一区二区视频| 中文 成人 在线 视频| 91免费观看在线网站| 蜜桃视频入口久久久| 五月婷婷在线观看视频免费| 伊人开心婷婷国产av| 亚国产成人精品久久久| 国产普通话插插视频| 99热这里只有国产精品6| 18禁精品网站久久| 国产精品自拍偷拍a| sw137 中文字幕 在线| 成年人的在线免费视频| 93精品视频在线观看| 亚洲精品无码久久久久不卡| 蜜桃专区一区二区在线观看| 久久尻中国美女视频| 嫩草aⅴ一区二区三区| 亚洲成人av一区久久| 99热国产精品666| 国产女人叫床高潮大片视频| 欧美亚洲免费视频观看| 免费男阳茎伸入女阳道视频| 宅男噜噜噜666免费观看| 免费观看污视频网站| 岛国毛片视频免费在线观看| 91在线免费观看成人| 91麻豆精品秘密入口在线观看| 秋霞午夜av福利经典影视| 青青草原网站在线观看| 日韩美在线观看视频黄| 日本成人不卡一区二区| 亚洲成人国产综合一区| 九色精品视频在线播放| 在线观看的黄色免费网站| 91精品国产麻豆国产| 亚洲欧美福利在线观看| 香蕉91一区二区三区| 亚洲精品亚洲人成在线导航| 91在线视频在线精品3| 亚洲一区二区三区久久受| 亚洲一区二区三区五区| 传媒在线播放国产精品一区| 硬鸡巴动态操女人逼视频| 亚洲一区二区久久久人妻| 精品少妇一二三视频在线| 日日操综合成人av| 福利片区一区二体验区| 男女第一次视频在线观看| 日比视频老公慢点好舒服啊| 大鸡巴操b视频在线| 免费观看丰满少妇做受| 97人人妻人人澡人人爽人人精品| 免费费一级特黄真人片| 国产一区二区久久久裸臀| 国产黄色a级三级三级三级| 精品老妇女久久9g国产| 大陆av手机在线观看| 很黄很污很色的午夜网站在线观看| 亚洲中文字字幕乱码| 动色av一区二区三区| yellow在线播放av啊啊啊| 青青青视频手机在线观看| 人妻熟女中文字幕aⅴ在线| 精品成人午夜免费看| 大白屁股精品视频国产| 久久精品36亚洲精品束缚| 亚洲av男人天堂久久| 日本午夜爽爽爽爽爽视频在线观看| 97小视频人妻一区二区| 999九九久久久精品| 偷拍美女一区二区三区| 国产精品亚洲а∨天堂免| 中国视频一区二区三区| 91片黄在线观看喷潮| 天天操天天爽天天干| 综合激情网激情五月五月婷婷| 天天干狠狠干天天操 | 夜夜骑夜夜操夜夜奸| 日日夜夜大香蕉伊人| 欧洲亚洲欧美日韩综合| 日韩二区视频一线天婷婷五| 国产精品久久久久国产三级试频| www日韩毛片av| 亚洲国产精品中文字幕网站| 78色精品一区二区三区| 99re6热在线精品| 最新国产精品网址在线观看| 亚洲图片欧美校园春色| 日本裸体熟妇区二区欧美| 国产精品久久综合久久| 中文字幕乱码人妻电影| 一区二区视频在线观看视频在线| 丝袜美腿视频诱惑亚洲无 | 人人爽亚洲av人人爽av| 青青草国内在线视频精选| 性感美女诱惑福利视频| 欧洲欧美日韩国产在线| 国产精品亚洲а∨天堂免| 任你操视频免费在线观看| 天天操天天操天天碰| 午夜福利人人妻人人澡人人爽| 91久久综合男人天堂| 精品国产成人亚洲午夜| 天美传媒mv视频在线观看| 亚洲精品 欧美日韩| 亚洲午夜伦理视频在线| 98视频精品在线观看| 日本女人一级免费片| 国产成人精品av网站| 天堂av狠狠操蜜桃| 91极品大一女神正在播放| 黄色在线观看免费观看在线| 青娱乐极品视频青青草| 中文字幕乱码人妻电影| 成年人黄视频在线观看| 少妇人妻久久久久视频黄片| 美女av色播在线播放| 天天日天天爽天天干| 又粗又长 明星操逼小视频 | 女生被男生插的视频网站| 93视频一区二区三区| 偷偷玩弄新婚人妻h视频| 久久一区二区三区人妻欧美| 瑟瑟视频在线观看免费视频| 日韩欧美制服诱惑一区在线| 国产精品sm调教视频| 欧美亚洲一二三区蜜臀| 久久99久久99精品影院| 91精品啪在线免费| 亚洲精品成人网久久久久久小说| 五十路av熟女松本翔子| 国产精品入口麻豆啊啊啊| 超碰97免费人妻麻豆| 中文字幕一区二 区二三区四区| 国产精品视频男人的天堂| 国产污污污污网站在线| 久草视频在线一区二区三区资源站| 欧美黑人与人妻精品| 亚洲精品ww久久久久久| 亚洲高清国产一区二区三区| 欧美黑人性猛交xxxxⅹooo| 久久这里只有精彩视频免费| 久久久久久久一区二区三| 欧美国产亚洲中英文字幕| 97精品人妻一区二区三区精品| 黄色片黄色片wyaa| 亚洲一区二区三区久久受 | 欧美另类重口味极品在线观看| 国产a级毛久久久久精品| 美女 午夜 在线视频| av天堂中文免费在线| 国产亚洲四十路五十路| 欧亚日韩一区二区三区观看视频| 老司机欧美视频在线看| 中文字幕在线视频一区二区三区 | 99久久久无码国产精品性出奶水 | 精品一区二区亚洲欧美| 精品一区二区三区欧美| 最新欧美一二三视频| 成人久久精品一区二区三区| 天天日天天日天天擦| 一二三中文乱码亚洲乱码one| 久久久久久久一区二区三| 日比视频老公慢点好舒服啊| 99人妻视频免费在线| 51国产成人精品视频| 青青青青青免费视频| 姐姐的朋友2在线观看中文字幕| 黄页网视频在线免费观看 | 精品视频国产在线观看| h国产小视频福利在线观看| 亚洲精品无码久久久久不卡| 久久久久久国产精品| 青青草亚洲国产精品视频| 深夜男人福利在线观看| 亚洲国产欧美一区二区丝袜黑人| 狍和女人的王色毛片| 国产一区二区三免费视频| 精品美女福利在线观看| 亚洲欧美激情人妻偷拍| 亚洲国产欧美一区二区丝袜黑人| 国产性色生活片毛片春晓精品| 中文字幕在线观看极品视频| 日韩av中文在线免费观看| 91成人精品亚洲国产| 中文字幕AV在线免费看 | 2022精品久久久久久中文字幕| 91人妻精品久久久久久久网站| 久久精品国产999| 欧美日本在线视频一区| 天天干天天插天天谢| 亚洲一区av中文字幕在线观看| 九色视频在线观看免费| 国产91久久精品一区二区字幕| 成人av电影免费版| 在线免费观看日本片| 爱有来生高清在线中文字幕| 视频 一区二区在线观看| 天天干天天操天天摸天天射| 欧美专区第八页一区在线播放| 天天日天天干天天搡| 日韩精品二区一区久久| 亚洲伊人色一综合网| 国产又粗又黄又硬又爽| 国产片免费观看在线观看| 91麻豆精品秘密入口在线观看| 老司机99精品视频在线观看| 欧美一区二区三区久久久aaa| 久久久久久久久久一区二区三区| 老司机免费视频网站在线看| 中文字幕在线观看极品视频| 中文字幕在线观看国产片| 国产高清97在线观看视频| 亚洲中文字幕国产日韩| 91久久人澡人人添人人爽乱| 日韩无码国产精品强奸乱伦| 国产白嫩美女一区二区| 偷拍自拍 中文字幕| 最新97国产在线视频| sspd152中文字幕在线| 成人乱码一区二区三区av| 精品视频一区二区三区四区五区| 免费观看国产综合视频| 99精品视频之69精品视频| 青青青青青青青青青青草青青| 专门看国产熟妇的网站| 在线播放一区二区三区Av无码| 黑人巨大精品欧美视频| 国产老熟女伦老熟妇ⅹ| 日本乱人一区二区三区| 久久艹在线观看视频| 国产97视频在线精品| 成人亚洲精品国产精品 | 18禁网站一区二区三区四区 | 欧美日韩亚洲国产无线码| 日韩中文字幕福利av| 国产欧美精品一区二区高清| av天堂资源最新版在线看| av在线免费观看亚洲天堂| 黄色片黄色片wyaa| 亚洲成人午夜电影在线观看 | chinese国产盗摄一区二区| 国产1区,2区,3区| 老鸭窝在线观看一区| 男人天堂最新地址av| 免费十精品十国产网站| 亚洲熟妇久久无码精品| 精彩视频99免费在线| 伊人开心婷婷国产av| 沈阳熟妇28厘米大战黑人| 亚洲美女高潮喷浆视频| 91欧美在线免费观看| 欧美黄色录像免费看的| 天天干狠狠干天天操 | 熟女俱乐部一二三区| 超碰在线中文字幕一区二区| 久久三久久三久久三久久| 岛国毛片视频免费在线观看| 日韩视频一区二区免费观看| av中文字幕网址在线| av网址在线播放大全| 亚洲 国产 成人 在线| 1000部国产精品成人观看视频| 在线观看911精品国产| 在线制服丝袜中文字幕| 91‖亚洲‖国产熟女| 亚洲高清自偷揄拍自拍| 国产一级麻豆精品免费| 这里有精品成人国产99| 日本美女性生活一级片| 五十路熟女人妻一区二区9933 | 成人蜜桃美臀九一一区二区三区| 4个黑人操素人视频网站精品91| 密臀av一区在线观看| 青青青青青手机视频| 国产超码片内射在线| 欧美成人黄片一区二区三区| 早川濑里奈av黑人番号| 亚洲中文字字幕乱码| 日韩二区视频一线天婷婷五| 大鸡吧插入女阴道黄色片| 国产精品国产三级麻豆| 又黄又刺激的午夜小视频| 国产白嫩美女一区二区| 欧美国产亚洲中英文字幕| 国产av国片精品一区二区| 午夜福利人人妻人人澡人人爽| av在线播放国产不卡| 亚洲狠狠婷婷综合久久app| 久草视频 久草视频2| 欧美在线偷拍视频免费看 | 精品少妇一二三视频在线| 制丝袜业一区二区三区| 69精品视频一区二区在线观看| yellow在线播放av啊啊啊| 91色九色porny| 亚洲精品福利网站图片| 一区二区三区日韩久久| 美女被肏内射视频网站| 亚洲美女高潮喷浆视频| 国产超码片内射在线| av在线观看网址av| 亚洲免费福利一区二区三区| 韩国一级特黄大片做受| 欧美成人综合色在线噜噜| 中文字幕AV在线免费看 | 搞黄色在线免费观看| 黑人乱偷人妻中文字幕| 亚洲一区二区激情在线| 国产不卡av在线免费| 狠狠躁狠狠爱网站视频| 天天操,天天干,天天射| 91中文字幕最新合集| 日韩北条麻妃一区在线| 中文字幕av熟女人妻| 亚洲免费成人a v| 可以免费看的www视频你懂的| 欧美另类一区二区视频| av手机在线免费观看日韩av| 国产精品国产三级国产午| 红桃av成人在线观看| 中文字幕在线乱码一区二区 | 亚洲av极品精品在线观看| 亚洲欧美综合另类13p| 少妇深喉口爆吞精韩国| 成人亚洲国产综合精品| 成人影片高清在线观看 | 国产黄色高清资源在线免费观看| 天天插天天狠天天操| 亚洲午夜伦理视频在线| 日本人妻精品久久久久久| 日本午夜福利免费视频| 美日韩在线视频免费看| 中文字幕午夜免费福利视频| 狠狠操狠狠操免费视频| 欧美日韩熟女一区二区三区| 成人亚洲国产综合精品| 日日夜夜精品一二三| 日本午夜久久女同精女女| asmr福利视频在线观看| huangse网站在线观看| 国产高潮无码喷水AV片在线观看| 在线免费观看亚洲精品电影| 黄色成人在线中文字幕| 免费观看污视频网站| av手机免费在线观看高潮| 精品人人人妻人人玩日产欧| 一区二区视频在线观看免费观看| 日本人竟这样玩学生妹| 亚洲超碰97人人做人人爱| 色婷婷久久久久swag精品| 经典av尤物一区二区| 亚洲一级美女啪啪啪| 狠狠躁夜夜躁人人爽天天久天啪| 男人天堂最新地址av| 亚洲av无女神免非久久| 女同性ⅹxx女同hd| 国产欧美日韩在线观看不卡| 天天日天天敢天天干| 夜鲁夜鲁狠鲁天天在线| 日韩在线中文字幕色| 欧美日韩在线精品一区二区三| 男人操女人逼逼视频网站| 超碰97免费人妻麻豆| 国产精品人妻熟女毛片av久| 在线观看成人国产电影| 淫秽激情视频免费观看| 亚洲卡1卡2卡三卡四老狼| 97人妻无码AV碰碰视频| 男人的天堂在线黄色| 久久久久久97三级| 丰满的继坶3中文在线观看| 一级a看免费观看网站| 蜜臀av久久久久久久| 午夜大尺度无码福利视频| 一区二区三区四区五区性感视频| 国产伦精品一区二区三区竹菊| 视频一区二区在线免费播放| 午夜精品亚洲精品五月色| 丝袜长腿第一页在线| 老有所依在线观看完整版| 一区二区三区视频,福利一区二区| 丰满熟女午夜福利视频| 天堂女人av一区二区| 天天干夜夜操啊啊啊| 中文字幕熟女人妻久久久| 午夜91一区二区三区| 亚洲激情av一区二区| 中文字幕在线乱码一区二区| 丝袜美腿视频诱惑亚洲无| 97超碰国语国产97超碰| 日日操夜夜撸天天干| 欧美一级视频一区二区| 青娱乐极品视频青青草| 天天干天天操天天扣| 在线视频自拍第三页| 四川乱子伦视频国产vip| 亚洲综合乱码一区二区| 91欧美在线免费观看| 亚洲午夜电影在线观看| 国产精品一二三不卡带免费视频 | 欧美一区二区三区啪啪同性| 首之国产AV医生和护士小芳| 国产在线观看黄色视频| 91试看福利一分钟| 亚洲精品国产久久久久久| 大香蕉福利在线观看| 动漫精品视频在线观看| 日韩美女搞黄视频免费| 天堂女人av一区二区| 综合精品久久久久97| 99精品免费久久久久久久久a| 一级a看免费观看网站| 九九视频在线精品播放| 亚洲推理片免费看网站| 日本三极片中文字幕| 日韩欧美国产一区不卡| 91精品综合久久久久3d动漫 | 大鸡吧插逼逼视频免费看| 天天操夜夜骑日日摸| 久久艹在线观看视频| 夜夜嗨av蜜臀av| 这里只有精品双飞在线播放| 亚洲精品ww久久久久久| 一区二区麻豆传媒黄片| 成人24小时免费视频| 亚洲成人三级在线播放| 97超碰免费在线视频| 丁香花免费在线观看中文字幕| 亚洲成人av一区久久| 日本午夜福利免费视频| 色综合久久久久久久久中文| 国产黄色片蝌蚪九色91| 成人乱码一区二区三区av| 天天做天天干天天舔| 亚洲av天堂在线播放| 欧美乱妇无乱码一区二区| 特一级特级黄色网片| 亚洲国产欧美国产综合在线| rct470中文字幕在线| 阿v天堂2014 一区亚洲| 国产成人自拍视频播放| 好吊操视频这里只有精品| 1000小视频在线| 播放日本一区二区三区电影| 国产三级精品三级在线不卡| 97人人妻人人澡人人爽人人精品| 在线观看视频网站麻豆| 日韩av大胆在线观看| 亚洲国产欧美一区二区丝袜黑人| 天天日天天爽天天爽| 日韩人妻丝袜中文字幕| 激情伦理欧美日韩中文字幕 | 家庭女教师中文字幕在线播放| 国产又粗又黄又硬又爽| 国产综合视频在线看片| 亚洲熟女久久久36d| 99一区二区在线观看| 人人妻人人爽人人添夜| 一级黄色片夫妻性生活| av完全免费在线观看av| 日本av高清免费网站| 日本一区精品视频在线观看| 熟女妇女老妇一二三区| 不卡日韩av在线观看| 水蜜桃一区二区三区在线观看视频| 中英文字幕av一区| 国产实拍勾搭女技师av在线| 色伦色伦777国产精品| 偷拍自拍视频图片免费| 动漫美女的小穴视频| 91九色国产porny蝌蚪| 黑人巨大的吊bdsm| 日韩欧美一级精品在线观看| 中文字幕一区二区三区人妻大片| 亚洲国产成人在线一区| 成人性爱在线看四区| 91欧美在线免费观看| 亚洲女人的天堂av| 熟女人妻在线中出观看完整版| 欧美精品中文字幕久久二区| 欧美交性又色又爽又黄麻豆| 99久久99久国产黄毛片| 93精品视频在线观看| av手机在线观播放网站| 亚国产成人精品久久久| 国产精品黄页网站视频| 日韩一区二区三区三州| av天堂加勒比在线| 蜜臀av久久久久蜜臀av麻豆| 一区二区三区四区中文| 亚洲免费va在线播放| 在线免费观看日本片| 懂色av蜜桃a v| 嫩草aⅴ一区二区三区| av无限看熟女人妻另类av| 国产一区自拍黄视频免费观看| 91九色porny国产在线| 欧美精品一区二区三区xxxx| 啪啪啪啪啪啪啪啪av| 中国黄片视频一区91| 日日操夜夜撸天天干| 天天日夜夜干天天操| 福利视频广场一区二区| 狠狠躁狠狠爱网站视频| 日本人妻欲求不满中文字幕| 大香蕉日本伊人中文在线| 老司机深夜免费福利视频在线观看| 久久久极品久久蜜桃| 一区二区三区av高清免费| 亚洲少妇高潮免费观看| 精品国产成人亚洲午夜| 亚洲 中文 自拍 另类 欧美| 含骚鸡巴玩逼逼视频| 免费岛国喷水视频在线观看| 97精品综合久久在线| huangse网站在线观看| 免费大片在线观看视频网站| 无码精品一区二区三区人 | 天天躁夜夜躁日日躁a麻豆| 日韩少妇人妻精品无码专区| 日本一二三区不卡无| 久久久91蜜桃精品ad| 9色在线视频免费观看| 扒开让我视频在线观看| 国产精品久久9999| 天天摸天天亲天天舔天天操天天爽| 亚洲美女自偷自拍11页| 天天日天天舔天天射进去| 一区二区三区久久中文字幕| 91中文字幕最新合集| 偷拍自拍 中文字幕| 丰满少妇翘臀后进式| 国产精品国产三级国产午| www天堂在线久久| 美女大bxxxx内射| 天天日天天舔天天射进去| 日韩精品电影亚洲一区| 日本一区二区三区免费小视频| 成人高潮aa毛片免费| 日韩欧美在线观看不卡一区二区 | 亚洲国产中文字幕啊啊啊不行了 | a v欧美一区=区三区| 免费观看丰满少妇做受| 国产麻豆精品人妻av| 日韩成人性色生活片| 国产精品人久久久久久| 91精品国产高清自在线看香蕉网| 中文字幕一区二区三区蜜月| 一区二区三区四区视频| 日韩伦理短片在线观看| 老司机欧美视频在线看| 青青青激情在线观看视频| 欧美成人综合色在线噜噜| 国产福利小视频大全| 美味人妻2在线播放| 11久久久久久久久久久| 亚洲视频在线观看高清| 少妇人妻二三区视频| 久久免费看少妇高潮完整版| www久久久久久久久久久| 日韩亚洲高清在线观看| 一级A一级a爰片免费免会员| 色哟哟国产精品入口| 丰满的子国产在线观看| 欧美黄色录像免费看的| caoporn蜜桃视频| 在线播放一区二区三区Av无码| 韩国三级aaaaa高清视频| 午夜久久久久久久精品熟女| 日本少妇在线视频大香蕉在线观看 | 亚洲av日韩精品久久久| av在线观看网址av| 久久久久久久精品成人热| 92福利视频午夜1000看| 热思思国产99re| 中文字幕乱码人妻电影| 青青在线视频性感少妇和隔壁黑丝| 高潮视频在线快速观看国家快速| 少妇高潮无套内谢麻豆| 超污视频在线观看污污污| 人妻无码中文字幕专区| 国产欧美精品不卡在线| 亚洲1区2区3区精华液| 日韩熟女系列一区二区三区| 欧美视频中文一区二区三区| 日韩熟女系列一区二区三区| 黄色av网站免费在线| 色狠狠av线不卡香蕉一区二区 | 9久在线视频只有精品| 国产一级精品综合av| 欧美精产国品一二三产品区别大吗| 欧美日韩精品永久免费网址 | 国产精品久久久久久久精品视频| 欧美另类重口味极品在线观看| 日本黄色三级高清视频| 自拍偷拍 国产资源| 国产在线一区二区三区麻酥酥| 自拍偷拍vs一区二区三区| 亚洲av日韩高清hd| 亚洲欧美精品综合图片小说| 91免费黄片可看视频| 免费人成黄页网站在线观看国产 | 午夜精品福利一区二区三区p| 福利在线视频网址导航| 日本性感美女写真视频| 青娱乐在线免费视频盛宴| 久久久久国产成人精品亚洲午夜| 内射久久久久综合网| 又粗又硬又猛又黄免费30| 亚洲av日韩av网站| 自拍偷拍 国产资源| 岛国黄色大片在线观看| 亚洲一级av大片免费观看| 91大屁股国产一区二区| 日本xx片在线观看| 97人人模人人爽人人喊| 性感美女福利视频网站| 国产日韩精品免费在线| 人妻丝袜精品中文字幕| 黑人巨大的吊bdsm| 直接能看的国产av| 亚洲熟妇x久久av久久| 欧美性感尤物人妻在线免费看| 欧美偷拍亚洲一区二区| 丰满少妇人妻xxxxx| 91色九色porny| 国产变态另类在线观看| 换爱交换乱高清大片| 成年美女黄网站18禁久久| 日本一区美女福利视频| 不卡一不卡二不卡三| 在线观看视频一区麻豆| 11久久久久久久久久久| 久草电影免费在线观看| 又粗又长 明星操逼小视频| 欧美黄片精彩在线免费观看 | 成人乱码一区二区三区av| 成人亚洲国产综合精品| 亚洲欧洲一区二区在线观看| 美女日逼视频免费观看| 日韩欧美国产精品91| 亚洲最大黄了色网站| 日本精品视频不卡一二三| 热99re69精品8在线播放| 欧美va不卡视频在线观看| 久久精品久久精品亚洲人| 欧美日韩情色在线观看| 黄色成年网站午夜在线观看| 91麻豆精品秘密入口在线观看| 99久久中文字幕一本人| 人妻丝袜诱惑我操她视频| 夜夜骑夜夜操夜夜奸| 国产黑丝高跟鞋视频在线播放| 亚洲中文字幕乱码区| 绝顶痉挛大潮喷高潮无码| 激情综合治理六月婷婷| 综合激情网激情五月天| 色吉吉影音天天干天天操| 青青尤物在线观看视频网站| 精品美女在线观看视频在线观看| 亚洲av男人天堂久久| 天天日天天摸天天爱| 91极品大一女神正在播放| 欧美成人猛片aaaaaaa| 最新91九色国产在线观看| 日韩欧美一级aa大片| 日韩美女精品视频在线观看网站 | 在线亚洲天堂色播av电影| av天堂中文免费在线| 黄色片年轻人在线观看| 婷婷综合蜜桃av在线| 在线可以看的视频你懂的| 白白操白白色在线免费视频| 少妇深喉口爆吞精韩国| 黑人乱偷人妻中文字幕| 丁香花免费在线观看中文字幕| 丝袜肉丝一区二区三区四区在线看| 免费一级黄色av网站| 日本午夜福利免费视频| 国产福利小视频免费观看| 国产1区,2区,3区| 果冻传媒av一区二区三区| 久久久超爽一二三av| 日韩二区视频一线天婷婷五| 日本av高清免费网站| 亚洲高清国产拍青青草原| 青青青青青操视频在线观看| 天天日天天干天天插舔舔| 亚洲精品国产久久久久久| 91久久综合男人天堂| av天堂加勒比在线| 美女福利视频网址导航| 久久精品国产999| 久久久精品999精品日本| 亚洲精品欧美日韩在线播放| 91啪国自产中文字幕在线| 国产精品入口麻豆啊啊啊| 日本丰满熟妇BBXBBXHD| 热久久只有这里有精品| 日韩美av高清在线| 福利视频一区二区三区筱慧| 可以免费看的www视频你懂的| 日韩欧美国产一区ab| 亚洲1卡2卡三卡4卡在线观看 | 亚洲青青操骚货在线视频| 青青青国产免费视频| 天天日天天干天天要| 国产在线观看免费人成短视频| 99久久激情婷婷综合五月天| 五月婷婷在线观看视频免费| 亚洲一区二区三区五区 | 亚洲综合在线观看免费| 久久精品亚洲成在人线a| 免费观看丰满少妇做受| 免费高清自慰一区二区三区网站| 免费看美女脱光衣服的视频| 日韩a级黄色小视频| 熟女人妻一区二区精品视频| 亚洲综合在线视频可播放| 综合页自拍视频在线播放| 五十路丰满人妻熟妇| 国产精品探花熟女在线观看| 中文字幕高清在线免费播放 | 97黄网站在线观看| 婷婷综合亚洲爱久久| sspd152中文字幕在线| jiujiure精品视频在线| 日本男女操逼视频免费看| 欧美日韩精品永久免费网址| 欧美精品资源在线观看| 国产高清97在线观看视频| 女同性ⅹxx女同h偷拍| 午夜av一区二区三区| 午夜毛片不卡免费观看视频| 天天日天天操天天摸天天舔| 蜜桃专区一区二区在线观看| 日韩欧美国产精品91| 精品视频中文字幕在线播放| 亚洲av黄色在线网站| 岛国免费大片在线观看| a v欧美一区=区三区| 在线观看黄色成年人网站| 国产亚州色婷婷久久99精品| 亚洲护士一区二区三区| 亚洲日本一区二区久久久精品| 欧美一级视频一区二区| 亚洲综合另类精品小说| 国产福利小视频免费观看| 国产精品久久久黄网站| 欧美地区一二三专区| 美女操逼免费短视频下载链接 | 女同性ⅹxx女同h偷拍| 伊人网中文字幕在线视频| 亚洲午夜电影在线观看| 国产精品国产三级麻豆| 性色av一区二区三区久久久| 99一区二区在线观看| 久碰精品少妇中文字幕av| 亚洲欧美激情人妻偷拍| 中文字幕综合一区二区| 日本真人性生活视频免费看| 很黄很污很色的午夜网站在线观看 | 亚洲成人线上免费视频观看| 欧美亚洲少妇福利视频| 99的爱精品免费视频| 高潮视频在线快速观看国家快速| 啪啪啪啪啪啪啪啪啪啪黄色| 五十路息与子猛烈交尾视频| 青青青青视频在线播放| 91大神福利视频网| 亚洲精品 日韩电影| 狠狠躁狠狠爱网站视频| 男生用鸡操女生视频动漫 | 91精品国产黑色丝袜| 一区二区在线视频中文字幕| 嫩草aⅴ一区二区三区| 亚洲自拍偷拍精品网| 大肉大捧一进一出好爽在线视频 | 中文字幕在线免费第一页| 黄色的网站在线免费看| 97资源人妻免费在线视频| 中文字幕第一页国产在线| 端庄人妻堕落挣扎沉沦| 一区二区三区在线视频福利| 日日爽天天干夜夜操| 综合页自拍视频在线播放| 美女在线观看日本亚洲一区| 亚洲 中文 自拍 另类 欧美| 99热国产精品666| 日韩加勒比东京热二区| 日本免费一级黄色录像| 在线观看av2025| 一区二区三区四区五区性感视频 | 日韩成人综艺在线播放| 欧美精品亚洲精品日韩在线| 经典国语激情内射视频| 国产午夜激情福利小视频在线| 黄色片年轻人在线观看| 日本人妻少妇18—xx| 国产精品视频资源在线播放| 男人靠女人的逼视频| 97黄网站在线观看| 国产亚洲视频在线二区| 91破解版永久免费| 国产麻豆91在线视频| 水蜜桃一区二区三区在线观看视频| 久久农村老妇乱69系列| 亚洲1069综合男同| 春色激情网欧美成人| 中文字幕无码一区二区免费| 欧美日韩精品永久免费网址| 精品av国产一区二区三区四区| 韩国一级特黄大片做受| 日本丰满熟妇大屁股久久| 午夜福利人人妻人人澡人人爽| 丰满的继坶3中文在线观看| 2o22av在线视频| 亚洲综合在线视频可播放| 日日爽天天干夜夜操| 成年人中文字幕在线观看| 精品高潮呻吟久久av| 狠狠地躁夜夜躁日日躁| www天堂在线久久| 亚洲色偷偷综合亚洲AV伊人| 在线视频国产欧美日韩| 亚洲免费视频欧洲免费视频| av在线shipin| 天天日天天天天天天天天天天| 白嫩白嫩美女极品国产在线观看| 喷水视频在线观看这里只有精品| 久久永久免费精品人妻专区| 日韩黄色片在线观看网站| 国产成人一区二区三区电影网站| 欧美特色aaa大片| 狠狠躁狠狠爱网站视频| 97精品综合久久在线| 天美传媒mv视频在线观看| 久碰精品少妇中文字幕av| 日本一区美女福利视频| 5528327男人天堂| 沈阳熟妇28厘米大战黑人| 3344免费偷拍视频| 中文字幕国产专区欧美激情| 视频一区 二区 三区 综合| 亚洲成人精品女人久久久| 92福利视频午夜1000看| 亚洲国产精品久久久久蜜桃| 午夜精品久久久久久99热| 黄片色呦呦视频免费看| 天堂中文字幕翔田av| 无码精品一区二区三区人| 日本精品视频不卡一二三| 国产性感美女福利视频| 成人av久久精品一区二区| 性色蜜臀av一区二区三区| 欧美在线偷拍视频免费看| 久久麻豆亚洲精品av| 92福利视频午夜1000看| 丝袜肉丝一区二区三区四区在线|