国产无遮挡裸体免费直播视频,久久精品国产蜜臀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)論

丝袜长腿第一页在线| 2021久久免费视频| 国产av一区2区3区| 在线观看的a站 最新| 高清成人av一区三区| 免费手机黄页网址大全| av在线免费资源站| 亚洲高清视频在线不卡| 久久机热/这里只有| 亚洲av无码成人精品区辽| 亚洲最大免费在线观看| 亚洲国产精品中文字幕网站| 99一区二区在线观看| 人妻丝袜精品中文字幕| 日本真人性生活视频免费看| 久草福利电影在线观看| 亚洲 自拍 色综合图| 亚洲图库另类图片区| 国产视频精品资源网站| 狠狠操狠狠操免费视频| 国产亚洲视频在线二区| 亚洲精品三级av在线免费观看| 日本熟女精品一区二区三区| 亚洲成人免费看电影| 天天摸天天日天天操| 欧亚乱色一区二区三区| 沙月文乃人妻侵犯中文字幕在线 | 在线免费观看欧美小视频| 一区二区三区四区视频在线播放 | 99热这里只有国产精品6| 超级碰碰在线视频免费观看| 五月天久久激情视频| 亚洲在线免费h观看网站| 黄色成年网站午夜在线观看 | 在线观看国产网站资源| 中文字幕一区二 区二三区四区| 青青青激情在线观看视频| 国产福利小视频二区| av男人天堂狠狠干| 最新激情中文字幕视频| 亚洲色偷偷综合亚洲AV伊人| 高清成人av一区三区| 日韩美女搞黄视频免费| AV无码一区二区三区不卡| 免费一级黄色av网站| 操人妻嗷嗷叫视频一区二区| 97精品综合久久在线| 在线视频自拍第三页| 福利视频广场一区二区| 91亚洲国产成人精品性色| 亚洲av可乐操首页| 中国无遮挡白丝袜二区精品| 又大又湿又爽又紧A视频| 日本熟女精品一区二区三区| 国产日韩欧美视频在线导航| 日韩精品中文字幕播放| 91九色porny蝌蚪国产成人| 婷婷综合蜜桃av在线| 97黄网站在线观看| 欧美综合婷婷欧美综合| 天天日天天敢天天干| 88成人免费av网站| 亚洲高清视频在线不卡| 懂色av蜜桃a v| 亚洲免费av在线视频| 日本三极片中文字幕| 五月精品丁香久久久久福利社 | 国产一区二区久久久裸臀| 成年人该看的视频黄免费| 日韩av有码一区二区三区4 | 日本性感美女写真视频| 午夜蜜桃一区二区三区| 日本性感美女三级视频| 高清一区二区欧美系列| 国产一区二区欧美三区| 日曰摸日日碰夜夜爽歪歪| 很黄很污很色的午夜网站在线观看| 在线观看操大逼视频| 美日韩在线视频免费看| 久久久久久性虐视频| 久久永久免费精品人妻专区| 国产揄拍高清国内精品对白| 91人妻精品久久久久久久网站| 999九九久久久精品| 日本熟女精品一区二区三区| 亚洲Av无码国产综合色区| a v欧美一区=区三区| 亚洲久久午夜av一区二区| 中文字幕在线观看极品视频| 亚洲另类伦春色综合小| 日韩伦理短片在线观看| 日韩成人免费电影二区| 亚洲天堂第一页中文字幕| 亚洲美女美妇久久字幕组| 蜜桃久久久久久久人妻| 亚洲人妻30pwc| 中文字幕无码一区二区免费| 中文字幕之无码色多多| 东京热男人的av天堂| 18禁无翼鸟成人在线| 免费观看成年人视频在线观看| 老司机在线精品福利视频| 热99re69精品8在线播放| 男人和女人激情视频| 亚洲国产美女一区二区三区软件| 中文字幕 亚洲av| 亚洲第一黄色在线观看| 在线观看的黄色免费网站| 天天操天天弄天天射| jul—619中文字幕在线| 一区二区三区日本伦理| 91精品国产综合久久久蜜 | 18禁免费av网站| 免费无码人妻日韩精品一区二区| 人妻丝袜av在线播放网址| 六月婷婷激情一区二区三区| 午夜精品福利一区二区三区p | 91免费观看国产免费| 国产精品成久久久久三级蜜臀av| 午夜在线一区二区免费| 亚洲熟女女同志女同| 亚洲av天堂在线播放| 人妻少妇av在线观看| 免费岛国喷水视频在线观看 | 亚洲欧美国产麻豆综合| 日本裸体熟妇区二区欧美| 成人蜜臀午夜久久一区| 75国产综合在线视频| 色吉吉影音天天干天天操 | nagger可以指黑人吗| 一区二区三区毛片国产一区| 亚洲av天堂在线播放| 亚洲最大黄 嗯色 操 啊| 亚洲2021av天堂| 国产又大又黄免费观看| 北条麻妃高跟丝袜啪啪| 四川五十路熟女av| 欧美精品伦理三区四区| 大香蕉伊人国产在线| 色吉吉影音天天干天天操| 一区二区三区 自拍偷拍| 久久www免费人成一看片| 黄色中文字幕在线播放| 动漫精品视频在线观看| 中文字幕日韩91人妻在线| 日韩亚洲高清在线观看| 国产成人自拍视频在线免费观看| 伊人成人综合开心网| 日本真人性生活视频免费看| 黄工厂精品视频在线观看 | 一区二区三区综合视频| 国产一区自拍黄视频免费观看| 一区二区三区精品日本| 在线视频国产欧美日韩| 最新97国产在线视频| 不卡日韩av在线观看| 老师啊太大了啊啊啊尻视频| 欧美成一区二区三区四区| 快点插进来操我逼啊视频| 国产精品福利小视频a| 在线国产精品一区二区三区| 好吊操视频这里只有精品| 国产一区二区久久久裸臀| 国产欧美精品一区二区高清 | 2021天天色天天干| 国产久久久精品毛片| 啊啊好大好爽啊啊操我啊啊视频| 日韩人妻xxxxx| 日韩在线视频观看有码在线| 综合色区亚洲熟妇shxstz| 国产一级麻豆精品免费| 美女操逼免费短视频下载链接| 久久精品美女免费视频| 中文字幕av熟女人妻| 青青草原色片网站在线观看| 中国黄色av一级片| 曰本无码人妻丰满熟妇啪啪| 99国内小视频在现欢看| 亚洲av无码成人精品区辽| 午夜精品一区二区三区4| 久久精品36亚洲精品束缚| 精内国产乱码久久久久久| 性感美女高潮视频久久久| 激情五月婷婷免费视频| 亚洲天堂有码中文字幕视频| 十八禁在线观看地址免费| 日本后入视频在线观看| 热久久只有这里有精品| 欧美另类z0z变态| 国产品国产三级国产普通话三级| 噜噜色噜噜噜久色超碰| 中文字幕人妻三级在线观看| 强行扒开双腿猛烈进入免费版| 亚洲高清国产拍青青草原| 91超碰青青中文字幕| 成人高清在线观看视频| 亚洲麻豆一区二区三区| 免费观看理论片完整版| 精品日产卡一卡二卡国色天香| 成人区人妻精品一区二视频| 91国内视频在线观看| 91久久人澡人人添人人爽乱| 午夜在线观看一区视频| 在线观看欧美黄片一区二区三区| 大黑人性xxxxbbbb| 制服丝袜在线人妻中文字幕| 老司机欧美视频在线看| 老鸭窝日韩精品视频观看| 国产chinesehd精品麻豆| 五十路熟女人妻一区二| 欧美亚洲一二三区蜜臀| 91精品一区二区三区站长推荐| 成熟熟女国产精品一区| 97超碰免费在线视频| 国产视频一区在线观看| 免费无码人妻日韩精品一区二区| 人妻丝袜av在线播放网址| 色哟哟在线网站入口| 国产视频网站国产视频| 成年人中文字幕在线观看| 亚洲av无硬久久精品蜜桃| 大陆av手机在线观看| 日本男女操逼视频免费看| 一区二区三区另类在线| 欧亚日韩一区二区三区观看视频| 国内自拍第一页在线观看| 亚洲激情偷拍一区二区| 337p日本大胆欧美人| 韩国AV无码不卡在线播放 | 天天日天天爽天天爽| 成人综合亚洲欧美一区| 中文字幕视频一区二区在线观看| 久久精品亚洲国产av香蕉| 亚洲熟女久久久36d| 国产成人精品一区在线观看 | 在线播放一区二区三区Av无码| 视频 国产 精品 熟女 | 日日操夜夜撸天天干| 91免费黄片可看视频| 999九九久久久精品| 青青擦在线视频国产在线| 狠狠嗨日韩综合久久| 欧美精品国产综合久久| 在线免费视频 自拍| 爱有来生高清在线中文字幕| 毛片一级完整版免费| 亚洲欧美在线视频第一页| 国产午夜无码福利在线看| 三级av中文字幕在线观看| 天天日天天摸天天爱| 国产乱弄免费视频观看| 国产日本精品久久久久久久| 青青尤物在线观看视频网站| 亚洲欧美成人综合视频| 99热碰碰热精品a中文| jiujiure精品视频在线| 欧美麻豆av在线播放| 黄片大全在线观看观看| 亚洲乱码中文字幕在线| 黑人变态深video特大巨大| 国产+亚洲+欧美+另类| 性感美女福利视频网站| 姐姐的朋友2在线观看中文字幕| 国语对白xxxx乱大交| 欧美一级片免费在线成人观看| 一区二区三区四区中文| 青青草精品在线视频观看| 国产美女一区在线观看| 热久久只有这里有精品| 视频一区二区在线免费播放| 天天操夜夜操天天操天天操| 亚洲一区二区三区五区| 国产精品自拍视频大全| 亚洲天堂有码中文字幕视频| 精品美女久久久久久| 在线观看视频污一区| 国产美女一区在线观看| 岛国av高清在线成人在线| 日本脱亚入欧是指什么| 五十路老熟女码av| 日本特级片中文字幕| 93视频一区二区三区| 国产亚洲精品视频合集| 偷拍美女一区二区三区| 91精品国产高清自在线看香蕉网| 91啪国自产中文字幕在线| 亚洲一级av大片免费观看| 成人国产小视频在线观看| 亚洲另类图片蜜臀av| 男人插女人视频网站| 91香蕉成人app下载| 精品老妇女久久9g国产| 少妇一区二区三区久久久| 亚洲国产成人av在线一区| 亚洲公开视频在线观看| 人妻激情图片视频小说| 91亚洲手机在线视频播放| 中国黄色av一级片| 国产普通话插插视频| 东京干手机福利视频| 91小伙伴中女熟女高潮| 区一区二区三国产中文字幕| 日韩欧美中文国产在线| 五十路人妻熟女av一区二区| 淫秽激情视频免费观看| 99的爱精品免费视频| 姐姐的朋友2在线观看中文字幕| 国产不卡av在线免费| 蜜桃久久久久久久人妻| 免费十精品十国产网站| 夜夜躁狠狠躁日日躁麻豆内射 | 婷婷色国产黑丝少妇勾搭AV| 一区二区三区日本伦理| 久久丁香婷婷六月天| 国产内射中出在线观看| 啊用力插好舒服视频| 欧美一区二区中文字幕电影| 天天操天天弄天天射| 天天操天天操天天碰| 色哟哟国产精品入口| 91she九色精品国产| 天天日天天天天天天天天天天| 亚洲老熟妇日本老妇| 任你操任你干精品在线视频| 欧美熟妇一区二区三区仙踪林| 伊人精品福利综合导航| 亚洲欧美国产麻豆综合| 麻豆性色视频在线观看| av天堂中文字幕最新| 三级等保密码要求条款| 青娱乐蜜桃臀av色| 亚洲午夜精品小视频| 女生自摸在线观看一区二区三区| 午夜在线精品偷拍一区二| 综合国产成人在线观看| 国产av一区2区3区| 国产成人自拍视频在线免费观看| 在线观看日韩激情视频| 国产真实灌醉下药美女av福利| 色综合天天综合网国产成人| 粉嫩小穴流水视频在线观看| 又粗又硬又猛又黄免费30| 日本少妇的秘密免费视频| 国产激情av网站在线观看| 亚洲综合在线观看免费| 久久丁香婷婷六月天| 日韩欧美在线观看不卡一区二区| 年轻的人妻被夫上司侵犯| 亚洲国产香蕉视频在线播放| 免费一级黄色av网站| 欧美专区日韩专区国产专区| 亚洲欧美激情人妻偷拍| 岛国一区二区三区视频在线| 久久永久免费精品人妻专区| 天天色天天操天天舔| 爱有来生高清在线中文字幕| 日韩剧情片电影在线收看| rct470中文字幕在线| 抽查舔水白紧大视频| 熟女91pooyn熟女| 岛国毛片视频免费在线观看| 日本性感美女写真视频| 社区自拍揄拍尻屁你懂的| 日本a级视频老女人| 人妻自拍视频中国大陆| 东京热男人的av天堂| 人妻自拍视频中国大陆| 久久久久久久一区二区三| 欧美专区第八页一区在线播放| 大鸡巴插入美女黑黑的阴毛| 欧美亚洲偷拍自拍色图| 视频一区 二区 三区 综合| 黄网十四区丁香社区激情五月天 | 爆乳骚货内射骚货内射在线| 日韩近亲视频在线观看| 中文字幕av男人天堂| 日本脱亚入欧是指什么| 成年人啪啪视频在线观看| 99久久99一区二区三区| 人妻少妇亚洲精品中文字幕| 午夜成午夜成年片在线观看| 红桃av成人在线观看| 经典国语激情内射视频| 免费观看污视频网站| 亚洲美女自偷自拍11页| 亚洲av香蕉一区区二区三区犇| 69精品视频一区二区在线观看| 大学生A级毛片免费视频| 九色porny九色9l自拍视频| 91免费福利网91麻豆国产精品| 99re国产在线精品| 欧美日韩情色在线观看| 91chinese在线视频| 91麻豆精品91久久久久同性| 伊人开心婷婷国产av| 亚洲精品亚洲人成在线导航 | 九色精品视频在线播放| 久青青草视频手机在线免费观看| 亚洲欧洲一区二区在线观看| 人妻自拍视频中国大陆| 黄页网视频在线免费观看| 亚洲另类伦春色综合小| 中国老熟女偷拍第一页| 少妇高潮一区二区三区| 日本啪啪啪啪啪啪啪| 成人免费毛片aaaa| 天天操天天插天天色| 操人妻嗷嗷叫视频一区二区| 精品人妻每日一部精品| av视屏免费在线播放| 青青青爽视频在线播放| 欧美亚洲国产成人免费在线| 2025年人妻中文字幕乱码在线| 亚洲欧美色一区二区| 亚洲欧美色一区二区| 91久久人澡人人添人人爽乱| 日本少妇在线视频大香蕉在线观看| 青青青青青青青青青国产精品视频| 操操网操操伊剧情片中文字幕网| 成人福利视频免费在线| 欧美精产国品一二三产品价格| 国产伊人免费在线播放| 在线视频国产欧美日韩| 精品欧美一区二区vr在线观看| 日韩美女福利视频网| 日韩影片一区二区三区不卡免费| 夜夜操,天天操,狠狠操| 99久久成人日韩欧美精品| 日韩美av高清在线| 午夜久久香蕉电影网| 亚洲精品ww久久久久久| 久久免费看少妇高潮完整版| 欧美aa一级一区三区四区| 日韩精品中文字幕福利| 日韩欧美国产精品91| 晚上一个人看操B片| 日本三极片中文字幕| 自拍偷拍 国产资源| 丝袜国产专区在线观看| 中文字幕日韩精品日本| 亚洲男人的天堂a在线| 99久久中文字幕一本人| 亚洲欧美日韩视频免费观看| 亚洲国产最大av综合| 99精品国自产在线人| 日韩伦理短片在线观看| 含骚鸡巴玩逼逼视频| 色哟哟在线网站入口| 亚洲青青操骚货在线视频| 绝色少妇高潮3在线观看| 91麻豆精品传媒国产黄色片| 久草电影免费在线观看| 人妻3p真实偷拍一二区| 一区二区三区综合视频| 成人H精品动漫在线无码播放| 视频二区在线视频观看| 99热这里只有精品中文| 国产美女一区在线观看| 成年午夜影片国产片| 天天射夜夜操狠狠干| 天天操天天干天天艹| 欧美日韩一级黄片免费观看| 一区二区三区精品日本| 国产一区二区欧美三区| 欧美精品免费aaaaaa| 精产国品久久一二三产区区别| 中文字幕高清免费在线人妻| 极品粉嫩小泬白浆20p主播| 在线观看一区二区三级| 天天操天天弄天天射| 岛国一区二区三区视频在线| 精彩视频99免费在线| 国产成人精品福利短视频| 97人妻无码AV碰碰视频| 国产又大又黄免费观看| 91精品国产观看免费| 日韩精品啪啪视频一道免费| 国产精品久久久久网| 亚洲午夜电影之麻豆| 亚洲日产av一区二区在线| 国产普通话插插视频| av天堂资源最新版在线看| 精品人人人妻人人玩日产欧| 国产高清精品一区二区三区| 女人精品内射国产99| 亚洲 自拍 色综合图| 青青草精品在线视频观看| 91国内视频在线观看| 亚洲国产香蕉视频在线播放| 亚洲少妇人妻无码精品| 亚洲一区久久免费视频| 亚洲综合另类精品小说| 嫩草aⅴ一区二区三区| 中文字幕一区二区亚洲一区| 久草视频 久草视频2| 99re国产在线精品| 亚洲国产精品免费在线观看| 精品一区二区三区在线观看| 免费国产性生活视频| 日本18禁久久久久久| 亚洲精品在线资源站| 天美传媒mv视频在线观看| 天天色天天操天天舔| 欧美黄片精彩在线免费观看| 日本www中文字幕| 亚洲日本一区二区久久久精品| 亚洲精品无码色午夜福利理论片| 亚洲精品 欧美日韩| 中文字幕av熟女人妻| 搡老熟女一区二区在线观看| 亚洲欧美色一区二区| 少妇被强干到高潮视频在线观看| 欧美日韩亚洲国产无线码| 亚洲一级美女啪啪啪| 国产精品黄页网站视频| 国产在线免费观看成人| 免费国产性生活视频| 色综合久久久久久久久中文| 国产高清在线观看1区2区| 精品久久久久久高潮| 五十路息与子猛烈交尾视频| 端庄人妻堕落挣扎沉沦| 欲满人妻中文字幕在线| 97人妻色免费视频| rct470中文字幕在线| 黄色录像鸡巴插进去| 97国产精品97久久| 水蜜桃一区二区三区在线观看视频 | 日本成人不卡一区二区| av一区二区三区人妻| 亚洲精品在线资源站| 中文字幕在线观看极品视频| gogo国模私拍视频| 99精品视频之69精品视频| 中文字幕中文字幕 亚洲国产| 超级福利视频在线观看| 激情五月婷婷免费视频| 青娱乐蜜桃臀av色| 中文字幕无码日韩专区免费| 久草视频首页在线观看| 激情内射在线免费观看| 日韩亚洲高清在线观看| 中文字幕 亚洲av| 亚洲高清视频在线不卡| 伊拉克及约旦宣布关闭领空| 国产精品亚洲在线观看| 真实国产乱子伦一区二区| 激情伦理欧美日韩中文字幕| 51国产成人精品视频| 国产精品人妻一区二区三区网站| 日韩av熟妇在线观看| 国产精品视频一区在线播放| 51国产偷自视频在线播放| 欧美激情电影免费在线| 大鸡吧插逼逼视频免费看| av完全免费在线观看av| 天天躁夜夜躁日日躁a麻豆| 日本成人不卡一区二区| av大全在线播放免费| 国产又粗又猛又爽又黄的视频美国| 任我爽精品视频在线播放| 黄色片一级美女黄色片| 成人性爱在线看四区| 亚洲 欧美 精品 激情 偷拍| av天堂中文字幕最新| 亚洲一区二区三区精品乱码| 超碰在线观看免费在线观看| 天天干天天日天天谢综合156| 免费无码人妻日韩精品一区二区 | 久草免费人妻视频在线| 在线观看黄色成年人网站| 丝袜美腿欧美另类 中文字幕| 亚洲特黄aaaa片| 成人精品在线观看视频| 亚洲 人妻 激情 中文| 国产精彩对白一区二区三区 | 人人妻人人澡欧美91精品| 中文字幕亚洲中文字幕| 天天干天天操天天摸天天射| 天天操夜夜操天天操天天操 | 天天干天天日天天干天天操| 亚洲伊人久久精品影院一美女洗澡 | www天堂在线久久| 久久精品亚洲国产av香蕉| 天堂av在线官网中文| 日本一本午夜在线播放| 欧美亚洲免费视频观看| 91试看福利一分钟| 国产精品自拍在线视频| 日本一区美女福利视频| 亚洲精品一区二区三区老狼| 韩国爱爱视频中文字幕| 亚洲1卡2卡三卡4卡在线观看| 男人和女人激情视频| 日本韩国在线观看一区二区| 精品少妇一二三视频在线| 超碰97人人澡人人| 国产午夜亚洲精品不卡在线观看| 91中文字幕免费在线观看| 成熟熟女国产精品一区| 自拍偷拍亚洲欧美在线视频| 肏插流水妹子在线乐播下载| 亚洲成人免费看电影| huangse网站在线观看| 午夜大尺度无码福利视频| 亚洲中文字幕人妻一区| 无套猛戳丰满少妇人妻| av中文字幕网址在线| 欧美精品亚洲精品日韩在线| 久草视频 久草视频2| 亚洲一区二区三区精品视频在线| 在线观看av亚洲情色| 2012中文字幕在线高清| 日本av熟女在线视频| 精品国产午夜视频一区二区| 亚洲精品午夜久久久久| 日本一二三区不卡无| 国产在线一区二区三区麻酥酥| 国产免费av一区二区凹凸四季| 成人综合亚洲欧美一区| av天堂中文字幕最新| 欧美精品资源在线观看| 色噜噜噜噜18禁止观看| 夜色撩人久久7777| 国产精品黄片免费在线观看| 五月天色婷婷在线观看视频免费 | 国产va在线观看精品| 亚洲成人激情视频免费观看了| 久久精品美女免费视频| 天天日天天摸天天爱| 九九视频在线精品播放| 欧美香蕉人妻精品一区二区| 亚洲 清纯 国产com| 人妻少妇亚洲一区二区| sspd152中文字幕在线| 新婚人妻聚会被中出| 综合激情网激情五月天| 久久精品36亚洲精品束缚| 黄色大片男人操女人逼| 3344免费偷拍视频| 亚洲精品国产久久久久久| 久久免费看少妇高潮完整版| 人妻凌辱欧美丰满熟妇| 亚洲人妻30pwc| 偷拍美女一区二区三区| 福利视频网久久91| 亚洲免费va在线播放| 亚洲码av无色中文| 十八禁在线观看地址免费| 亚洲一区av中文字幕在线观看| 日韩熟女av天堂系列| 边摸边做超爽毛片18禁色戒| 亚洲综合另类欧美久久| 特一级特级黄色网片| 成年人的在线免费视频| 欧美男同性恋69视频| 在线新三级黄伊人网| 宅男噜噜噜666国产| 一区二区三区 自拍偷拍| 老司机免费视频网站在线看| 热思思国产99re| 天天插天天狠天天操| 亚洲熟女女同志女同| 免费黄高清无码国产| 中文字幕最新久久久| 我想看操逼黄色大片| 97年大学生大白天操逼| 欧美日韩一级黄片免费观看| 亚洲欧美成人综合在线观看| 小穴多水久久精品免费看| 久草视频中文字幕在线观看| 夜夜骑夜夜操夜夜奸| 91桃色成人网络在线观看| 欧美日韩熟女一区二区三区| 日韩少妇人妻精品无码专区| 日本五十路熟新垣里子| 五十路熟女人妻一区二| 人妻无码中文字幕专区| 在线免费观看亚洲精品电影| 精品国产在线手机在线| 扒开腿挺进肉嫩小18禁视频| 成人国产影院在线观看| 久久久久久性虐视频| 中文字幕 亚洲av| 岛国免费大片在线观看| 天天射,天天操,天天说| 麻豆性色视频在线观看| 国产精品自拍在线视频| 一区二区三区日韩久久| 日本女大学生的黄色小视频| 亚洲精品午夜久久久久| 亚洲成人免费看电影| 亚洲另类伦春色综合小| 国产在线观看免费人成短视频| 国产亚洲精品视频合集| 久久精品亚洲成在人线a| 中文字幕乱码av资源| 九九视频在线精品播放| 熟女在线视频一区二区三区| 大鸡吧插逼逼视频免费看| 国产黄色高清资源在线免费观看| 夜夜骑夜夜操夜夜奸| 国产女人露脸高潮对白视频| 色综合久久久久久久久中文| 精品国产成人亚洲午夜| 性色av一区二区三区久久久| 中文字幕在线乱码一区二区| 水蜜桃一区二区三区在线观看视频| 在线观看一区二区三级| 中文字幕欧美日韩射射一| 天天干天天操天天插天天日| 久久永久免费精品人妻专区| 懂色av之国产精品| 国产美女午夜福利久久| 久久香蕉国产免费天天| 青青青青在线视频免费观看| 一区二区三区四区视频在线播放| 欧美成人黄片一区二区三区 | 中文字幕 亚洲av| 成人24小时免费视频| 大肉大捧一进一出好爽在线视频 | 中国无遮挡白丝袜二区精品| 2022国产综合在线干| 一级A一级a爰片免费免会员| 国产精品视频一区在线播放| 国产精品视频资源在线播放| 亚洲熟妇久久无码精品| 欧美精品激情在线最新观看视频| 五十路人妻熟女av一区二区| 美女福利写真在线观看视频| 中文乱理伦片在线观看| 国产av自拍偷拍盛宴| 精品一线二线三线日本| 激情内射在线免费观看| 天天日天天鲁天天操| 狠狠躁狠狠爱网站视频 | 人妻激情图片视频小说| 天堂v男人视频在线观看| 成人av在线资源网站| av在线资源中文字幕| 国产福利在线视频一区| 日本熟妇一区二区x x| 99亚洲美女一区二区三区| 二区中出在线观看老师| 5528327男人天堂| 操日韩美女视频在线免费看| 91国偷自产一区二区三区精品| 日本一区美女福利视频| 精品久久久久久久久久久a√国产| 国产91久久精品一区二区字幕| 51国产偷自视频在线播放| 青青尤物在线观看视频网站| 久久久麻豆精亚洲av麻花| av手机在线免费观看日韩av| 水蜜桃国产一区二区三区| 日韩不卡中文在线视频网站| 久久国产精品精品美女| 亚洲推理片免费看网站| 免费在线福利小视频| 免费手机黄页网址大全| av中文字幕在线观看第三页| 日韩美女综合中文字幕pp| 日本乱人一区二区三区| av无限看熟女人妻另类av| 老有所依在线观看完整版| 日本韩国免费福利精品| 亚洲综合另类欧美久久| 国产激情av网站在线观看| 一区二区三区日本伦理| 亚洲中文精品字幕在线观看 | 国产一区二区视频观看| 97精品人妻一区二区三区精品| 美洲精品一二三产区区别| 国产精品大陆在线2019不卡| 亚洲高清国产拍青青草原| 动漫美女的小穴视频| 啊啊好大好爽啊啊操我啊啊视频 | av大全在线播放免费| 天天干天天操天天摸天天射| 白白操白白色在线免费视频| 人妻3p真实偷拍一二区| 免费一级特黄特色大片在线观看| 天天夜天天日天天日| 国产精品三级三级三级| 色婷婷综合激情五月免费观看| 香蕉91一区二区三区| 换爱交换乱高清大片| 国产精品精品精品999| 人妻少妇亚洲一区二区| 色97视频在线播放| 天堂av中文在线最新版| 风流唐伯虎电视剧在线观看| 好吊视频—区二区三区| sejizz在线视频| 国产免费av一区二区凹凸四季| 欧美80老妇人性视频| 欧美偷拍亚洲一区二区| 2020久久躁狠狠躁夜夜躁 | 中文字幕,亚洲人妻| 日本午夜久久女同精女女| 18禁免费av网站| 大香蕉福利在线观看| 亚洲成av人无码不卡影片一| 国产在线观看免费人成短视频| 国产女人被做到高潮免费视频| 一个人免费在线观看ww视频| 亚洲图片欧美校园春色| 亚洲的电影一区二区三区| 在线观看免费av网址大全| 国产精品久久久久国产三级试频| 99久久超碰人妻国产| 亚洲综合一区成人在线| 久青青草视频手机在线免费观看| 中国熟女一区二区性xx| 最新欧美一二三视频| 果冻传媒av一区二区三区 | 天天日天天舔天天射进去| 啪啪啪啪啪啪啪啪啪啪黄色| 日本韩国免费福利精品| 亚洲最大黄了色网站| 午夜精品一区二区三区4| 无码日韩人妻精品久久| 久草视频在线免播放| 2022天天干天天操| 中文字母永久播放1区2区3区| 免费观看理论片完整版| 一区国内二区日韩三区欧美| 亚洲一区二区三区在线高清| 99热色原网这里只有精品| 一区二区三区四区五区性感视频| 绝色少妇高潮3在线观看| 天天日天天透天天操| chinese国产盗摄一区二区| 中文字幕高清免费在线人妻| 九九视频在线精品播放| 国产麻豆国语对白露脸剧情 | 熟女在线视频一区二区三区| 毛片av在线免费看| 欧美viboss性丰满| 亚洲天堂有码中文字幕视频| 91桃色成人网络在线观看| 最新国产精品网址在线观看| 巨乳人妻日下部加奈被邻居中出 | 国产精品久久久久国产三级试频| 一区二区三区四区视频| 99婷婷在线观看视频| 777奇米久久精品一区| av久久精品北条麻妃av观看| 激情五月婷婷免费视频| 国产一区二区久久久裸臀| 天天操夜夜操天天操天天操| 男人操女人的逼免费视频| 一区二区熟女人妻视频| 欧美黑人巨大性xxxxx猛交| 91天堂精品一区二区| 国产一区二区欧美三区| 欧美色婷婷综合在线| 欧美黑人与人妻精品| 在线视频免费观看网| 婷婷综合亚洲爱久久| av网址国产在线观看| 激情国产小视频在线| 五十路丰满人妻熟妇| 久久www免费人成一看片| 精品日产卡一卡二卡国色天香 | 久久丁香婷婷六月天| 亚洲综合一区二区精品久久| 美洲精品一二三产区区别| 国产一区二区神马久久| 视频二区在线视频观看| 91亚洲精品干熟女蜜桃频道| 精品乱子伦一区二区三区免费播| 成人综合亚洲欧美一区| 97超碰免费在线视频| 免费观看成年人视频在线观看| 黄色视频成年人免费观看| 亚洲国产在线精品国偷产拍| 大鸡巴操b视频在线| 国产精品国色综合久久| 北条麻妃肉色丝袜视频| 在线观看免费视频网| 欧美精品 日韩国产| 亚洲激情av一区二区| 国产成人精品福利短视频| 春色激情网欧美成人| 国产品国产三级国产普通话三级| 91破解版永久免费| 精品一区二区三区在线观看| 天天日天天日天天射天天干| 91精品国产综合久久久蜜| 同居了嫂子在线播高清中文| 成人国产小视频在线观看| 亚洲熟女综合色一区二区三区四区| 制丝袜业一区二区三区| 国产伊人免费在线播放| 最新91精品视频在线| 日韩中文字幕在线播放第二页| 国产亚洲视频在线二区| 女警官打开双腿沦为性奴| 搡老熟女一区二区在线观看| 青青青青青青青青青青草青青| 人妻丰满熟妇综合网| 青青草原网站在线观看| 天天干天天插天天谢| 午夜精彩视频免费一区| 老司机你懂得福利视频| 在线观看一区二区三级| 天天操夜夜骑日日摸| av破解版在线观看| 国产在线观看免费人成短视频| 免费高清自慰一区二区三区网站 | 日韩特级黄片高清在线看| 精品成人啪啪18免费蜜臀| 成人色综合中文字幕| 日韩欧美一级精品在线观看| 宅男噜噜噜666免费观看| 亚洲天堂精品久久久| 午夜美女福利小视频| 免费高清自慰一区二区三区网站| 天天日天天爽天天爽| 经典国语激情内射视频| chinese国产盗摄一区二区| 亚洲精品av在线观看| 亚洲 色图 偷拍 欧美| 久久久久久久久久一区二区三区 | 天天操夜夜操天天操天天操| 欧美日韩高清午夜蜜桃大香蕉| 午夜影院在线观看视频羞羞羞| 91九色国产porny蝌蚪| 欧美一区二区三区激情啪啪啪| 欧美viboss性丰满| 国产亚州色婷婷久久99精品| 国产刺激激情美女网站| 中文字幕 人妻精品| 天天插天天色天天日| 亚洲午夜福利中文乱码字幕| 国产高潮无码喷水AV片在线观看| 91精品激情五月婷婷在线| 亚洲国产最大av综合| 亚洲高清免费在线观看视频| 亚洲成人精品女人久久久| v888av在线观看视频| 一区二区视频在线观看免费观看| 亚洲综合另类精品小说| 午夜国产福利在线观看| 18禁美女无遮挡免费| 激情五月婷婷免费视频| 精品日产卡一卡二卡国色天香| 中文字母永久播放1区2区3区| 国产一区二区火爆视频| 亚洲另类综合一区小说| 日韩欧美在线观看不卡一区二区| 偷拍美女一区二区三区| 精品老妇女久久9g国产| 欲乱人妻少妇在线视频裸| 欧美精品 日韩国产| 精产国品久久一二三产区区别| 丝袜亚洲另类欧美变态| 亚洲 国产 成人 在线| 天天干天天操天天玩天天射| 国产精品sm调教视频| 国产实拍勾搭女技师av在线| 亚洲福利精品视频在线免费观看| 亚洲天堂有码中文字幕视频| 亚洲av日韩精品久久久| 丰满的继坶3中文在线观看| 亚洲人妻30pwc| 一区二区三区另类在线| 影音先锋女人av噜噜色| 亚洲欧美成人综合在线观看| 天天干天天操天天摸天天射| 青青青视频自偷自拍38碰| 骚逼被大屌狂草视频免费看| 亚洲一区二区三区在线高清| caoporm超碰国产| 97人人模人人爽人人喊| 熟女在线视频一区二区三区| 精品91高清在线观看| 在线免费观看亚洲精品电影| 日本韩国在线观看一区二区| 社区自拍揄拍尻屁你懂的| 福利视频网久久91| www天堂在线久久| 2012中文字幕在线高清| 亚洲国产中文字幕啊啊啊不行了 | xxx日本hd高清| 美女吃鸡巴操逼高潮视频| 欧美一区二区三区高清不卡tv| 三级黄色亚洲成人av| v888av在线观看视频| 国产激情av网站在线观看| av天堂资源最新版在线看| 五月精品丁香久久久久福利社| 欧美在线偷拍视频免费看| 天天躁日日躁狠狠躁躁欧美av| av中文字幕福利网| 国产刺激激情美女网站| 任你操视频免费在线观看| av一本二本在线观看| 五十路人妻熟女av一区二区| 亚洲欧美国产麻豆综合| 精品人妻每日一部精品| 国产高清精品极品美女| 久精品人妻一区二区三区| 1区2区3区不卡视频| 亚洲 中文 自拍 无码| 午夜在线观看一区视频| 日本一道二三区视频久久 | 最近中文2019年在线看| 日韩精品中文字幕在线| 亚洲另类综合一区小说| 久久久久五月天丁香社区| 9l人妻人人爽人人爽| 2022国产综合在线干| 最后99天全集在线观看| 大骚逼91抽插出水视频| 青青青青操在线观看免费| 中文字幕av男人天堂| 99国内小视频在现欢看| 成人av久久精品一区二区| 国产成人精品av网站| 亚洲1区2区3区精华液| 四虎永久在线精品免费区二区| 亚洲国产香蕉视频在线播放| 边摸边做超爽毛片18禁色戒| 亚洲av自拍偷拍综合| 把腿张开让我插进去视频| 日韩激情文学在线视频| 成人高潮aa毛片免费| 亚洲 图片 欧美 图片| 日本男女操逼视频免费看| 国产精品国产三级麻豆| 成人国产影院在线观看| 伊人精品福利综合导航| 青青青青在线视频免费观看| 91老熟女连续高潮对白| 黄色成年网站午夜在线观看| 大鸡巴插入美女黑黑的阴毛| 中英文字幕av一区| 亚洲欧美激情国产综合久久久| 日本人妻欲求不满中文字幕| 日本一本午夜在线播放| 在线视频免费观看网| 日本后入视频在线观看| mm131美女午夜爽爽爽| 最新91精品视频在线| 91‖亚洲‖国产熟女| 毛片av在线免费看| 精品国产亚洲av一淫| 中国黄色av一级片| 国产chinesehd精品麻豆| 插小穴高清无码中文字幕| 欧美成人综合色在线噜噜| 自拍 日韩 欧美激情| 97香蕉碰碰人妻国产樱花| 日本少妇精品免费视频| 韩国黄色一级二级三级| 青青青青青青青青青青草青青| 日韩美在线观看视频黄| 亚洲丝袜老师诱惑在线观看| 中文字幕一区的人妻欧美日韩| 88成人免费av网站| 丝袜美腿欧美另类 中文字幕| 免费一级特黄特色大片在线观看| 国产激情av网站在线观看| 日韩视频一区二区免费观看| 亚洲第一黄色在线观看| 99热碰碰热精品a中文| jiuse91九色视频| 中文字幕第一页国产在线| 男女啪啪视频免费在线观看 | 精品国产在线手机在线| 日日夜夜大香蕉伊人| 成人区人妻精品一区二视频| 欧美成人综合视频一区二区 | 午夜频道成人在线91| 99精品国自产在线人| 国产精品免费不卡av| 一区二区三区综合视频| 欧美成人小视频在线免费看| 超碰97人人澡人人| 337p日本大胆欧美人| 黄色录像鸡巴插进去| 福利视频一区二区三区筱慧| 日韩一个色综合导航| 中文字幕第三十八页久久| 在线免费91激情四射| 国产黄色片在线收看| 粉嫩av懂色av蜜臀av| 国产性色生活片毛片春晓精品 | 91久久人澡人人添人人爽乱| 扒开腿挺进肉嫩小18禁视频| 国际av大片在线免费观看| 香蕉片在线观看av| 欧美黑人性猛交xxxxⅹooo| 啪啪啪啪啪啪啪啪啪啪黄色| 成年午夜影片国产片| 狠狠躁夜夜躁人人爽天天久天啪| 国产精品人妻66p| 亚洲av无硬久久精品蜜桃| 91精品激情五月婷婷在线| 日本韩国亚洲综合日韩欧美国产 | 果冻传媒av一区二区三区| 成人高清在线观看视频| 超级碰碰在线视频免费观看| 51精品视频免费在线观看| 天干天天天色天天日天天射| 人妻少妇亚洲一区二区| 成人色综合中文字幕| 99re国产在线精品| 日韩无码国产精品强奸乱伦| 久久农村老妇乱69系列| 中文字幕之无码色多多| 91香蕉成人app下载| 日本午夜爽爽爽爽爽视频在线观看| av完全免费在线观看av| 欧美日韩在线精品一区二区三| 一区二区三区四区中文| 免费一级特黄特色大片在线观看 | 亚洲一区二区三区在线高清| 插小穴高清无码中文字幕| 天天摸天天亲天天舔天天操天天爽| 精品久久久久久久久久久久人妻| 久久美欧人妻少妇一区二区三区| 91精品国产91青青碰| 91精品国产高清自在线看香蕉网 | 免费看美女脱光衣服的视频| 人妻自拍视频中国大陆| 欧美韩国日本国产亚洲| 99热色原网这里只有精品| 在线不卡成人黄色精品| 亚洲国产免费av一区二区三区| 一区二区三区av高清免费| 精品人妻伦一二三区久| 国产九色91在线观看精品| 19一区二区三区在线播放| 国产极品精品免费视频| 国产福利小视频免费观看| 最新激情中文字幕视频| 91 亚洲视频在线观看| 粉嫩av蜜乳av蜜臀| 熟女视频一区,二区,三区| 北条麻妃肉色丝袜视频| 亚洲激情,偷拍视频| 亚洲综合另类精品小说| 午夜精品福利91av| 色伦色伦777国产精品| 人妻丝袜诱惑我操她视频| 91www一区二区三区| 一区二区三区的久久的蜜桃的视频 | 青青青青青免费视频| 护士特殊服务久久久久久久| 高潮视频在线快速观看国家快速| 精品亚洲在线免费观看| 在线免费观看日本伦理| 亚洲成人激情视频免费观看了| 国产中文精品在线观看| 一级黄色片夫妻性生活| 日韩不卡中文在线视频网站| 亚洲熟女久久久36d| 日本黄在免费看视频| 国产精品一区二区久久久av| 国产高清在线观看1区2区| 国产精品精品精品999| 亚洲成高清a人片在线观看| 国产日韩一区二区在线看| 国产91嫩草久久成人在线视频| yellow在线播放av啊啊啊| 人人妻人人人操人人人爽| 精品久久久久久久久久久a√国产 日本女大学生的黄色小视频 | 婷婷色中文亚洲网68| 亚洲熟色妇av日韩熟色妇在线| 十八禁在线观看地址免费| 丰满的子国产在线观看| 美女日逼视频免费观看| 丝袜肉丝一区二区三区四区在线看| 欧美日韩一区二区电影在线观看| 日本一二三中文字幕| 久久久精品精品视频视频| 亚洲超碰97人人做人人爱| 女生被男生插的视频网站| 93精品视频在线观看| 男人的天堂在线黄色| 日韩av有码中文字幕| 欧美中国日韩久久精品| 中文字幕一区的人妻欧美日韩| 婷婷激情四射在线观看视频| 国产成人一区二区三区电影网站| 高潮视频在线快速观看国家快速| 天天色天天舔天天射天天爽| 黄页网视频在线免费观看| av一本二本在线观看| 阴茎插到阴道里面的视频| 亚洲高清国产一区二区三区| 亚洲一区二区三区av网站| 一区二区三区的久久的蜜桃的视频 | 日本女大学生的黄色小视频| 韩国男女黄色在线观看| 亚洲人妻视频在线网| 人妻av无码专区久久绿巨人| 在线制服丝袜中文字幕| 成人国产影院在线观看| 亚洲欧美自拍另类图片| 午夜激情精品福利视频| 亚洲av无码成人精品区辽| 玖玖一区二区在线观看| 国产成人综合一区2区| 五十路熟女人妻一区二| 亚洲午夜高清在线观看| 91自产国产精品视频| 国产91嫩草久久成人在线视频| 天天干狠狠干天天操| 超碰在线观看免费在线观看| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕+中文字幕| 91传媒一区二区三区| 懂色av之国产精品| 日本阿v视频在线免费观看| 黄色片黄色片wyaa| 黄片色呦呦视频免费看| 91精品国产91久久自产久强| 国产一区二区欧美三区| 亚洲激情,偷拍视频| 天天干天天操天天爽天天摸| 真实国模和老外性视频| 婷婷激情四射在线观看视频| 9久在线视频只有精品| 欧美久久一区二区伊人| 亚洲综合图片20p| 少妇人妻久久久久视频黄片| 都市家庭人妻激情自拍视频| 精品国产污污免费网站入口自| 色av色婷婷人妻久久久精品高清| 蜜臀av久久久久蜜臀av麻豆| 亚洲丝袜老师诱惑在线观看| 丝袜长腿第一页在线| 无码中文字幕波多野不卡| 风流唐伯虎电视剧在线观看| 桃色视频在线观看一区二区 | 五色婷婷综合狠狠爱| 久久久极品久久蜜桃| 99热这里只有精品中文| 黑人大几巴狂插日本少妇| 日韩成人免费电影二区| 女警官打开双腿沦为性奴| 在线观看免费岛国av| 亚洲va国产va欧美va在线| 亚洲av人人澡人人爽人人爱| 国产精品日韩欧美一区二区| 欧美麻豆av在线播放| 中文字幕日韩无敌亚洲精品| 韩国一级特黄大片做受| 人人在线视频一区二区| 久草视频在线看免费| 不卡日韩av在线观看| 99国产精品窥熟女精品| 一区二区免费高清黄色视频| av一区二区三区人妻| 黑人乱偷人妻中文字幕| 亚洲精品av在线观看| 国产自拍黄片在线观看| 在线免费观看靠比视频的网站| 色婷婷久久久久swag精品| 久久精品在线观看一区二区| 女同互舔一区二区三区| 青青青青青青青青青青草青青| 久久美欧人妻少妇一区二区三区| 免费无毒热热热热热热久| 日本av在线一区二区三区| 国产精品午夜国产小视频| 亚洲国产欧美国产综合在线| 国产麻豆精品人妻av| 啪啪啪啪啪啪啪啪av| 好吊视频—区二区三区| 黄色资源视频网站日韩| 四川乱子伦视频国产vip| 男人靠女人的逼视频| 色狠狠av线不卡香蕉一区二区| 久久久久91精品推荐99| 亚洲一区二区三区偷拍女厕91| 国产不卡av在线免费| 五色婷婷综合狠狠爱| 福利午夜视频在线观看| 久久久久久久久久久久久97| 大骚逼91抽插出水视频| 蜜桃专区一区二区在线观看| 国产精品女邻居小骚货| 这里有精品成人国产99| 特级欧美插插插插插bbbbb| 久久久久久9999久久久久| 中文字幕在线第一页成人| 天天综合天天综合天天网| AV天堂一区二区免费试看| 天天日天天爽天天爽| 亚洲伊人av天堂有码在线| 边摸边做超爽毛片18禁色戒 | 亚洲欧美一卡二卡三卡| 人妻久久无码中文成人| 年轻的人妻被夫上司侵犯| 亚洲精品麻豆免费在线观看| 精品黑人巨大在线一区| 日韩激情文学在线视频| 天天射夜夜操狠狠干| 无码中文字幕波多野不卡| 97人妻无码AV碰碰视频| 日本午夜福利免费视频| 孕妇奶水仑乱A级毛片免费看| 亚洲成人激情视频免费观看了| 欧美xxx成人在线| 一区二区三区久久中文字幕| 岛国黄色大片在线观看| 红杏久久av人妻一区| av破解版在线观看| 精品国产乱码一区二区三区乱| 1769国产精品视频免费观看| 91国产在线免费播放| 黄色资源视频网站日韩| 天天操天天干天天日狠狠插| 55夜色66夜色国产精品站| 狠狠躁夜夜躁人人爽天天久天啪| 视频一区二区综合精品| 1区2区3区不卡视频| 三级av中文字幕在线观看| 国产亚洲精品品视频在线| 国产超码片内射在线| 日韩欧美一级黄片亚洲| av手机免费在线观看高潮| 亚洲精品av在线观看| 国产高清精品一区二区三区| 扒开让我视频在线观看| 91老师蜜桃臀大屁股| 久青青草视频手机在线免费观看| 国产久久久精品毛片| 成人网18免费视频版国产| 午夜在线一区二区免费| 青青色国产视频在线| 欧美色婷婷综合在线| 91www一区二区三区| 亚洲精品乱码久久久久久密桃明 | 伊人日日日草夜夜草| 在线观看视频污一区| 阴茎插到阴道里面的视频| 大肉大捧一进一出好爽在线视频| 一区二区三区久久中文字幕| 美女福利写真在线观看视频| 在线免费观看黄页视频| 日本一区二区三区免费小视频| 欧美精品资源在线观看| 欧美黑人巨大性xxxxx猛交| 国产中文字幕四区在线观看| 一区二区三区综合视频| 一二三中文乱码亚洲乱码one| 中文字幕无码一区二区免费| 欧美精品伦理三区四区| 可以在线观看的av中文字幕| 黄色av网站免费在线| 蜜桃色婷婷久久久福利在线| 唐人色亚洲av嫩草| 制丝袜业一区二区三区| 日韩a级精品一区二区| 大陆胖女人与丈夫操b国语高清| 日韩黄色片在线观看网站| av久久精品北条麻妃av观看| 亚洲成人免费看电影| 91精品国产麻豆国产| 老有所依在线观看完整版| 国产chinesehd精品麻豆| 日本一二三中文字幕| free性日本少妇| 一区二区三区四区中文| 老有所依在线观看完整版| 国产一线二线三线的区别在哪| 深田咏美亚洲一区二区| 粉嫩av懂色av蜜臀av| 午夜毛片不卡免费观看视频| 喷水视频在线观看这里只有精品| 93人妻人人揉人人澡人人| 男人的天堂在线黄色| 欧美日本在线视频一区| 国产在线一区二区三区麻酥酥| 人妻凌辱欧美丰满熟妇| jul—619中文字幕在线| rct470中文字幕在线| 青青草精品在线视频观看| 国产欧美日韩第三页| 99热国产精品666| 亚洲av色图18p| 成人影片高清在线观看| 韩国亚洲欧美超一级在线播放视频| av破解版在线观看| 少妇人妻二三区视频 | 日韩剧情片电影在线收看| 免费一级特黄特色大片在线观看 | 97少妇精品在线观看| 日本免费一级黄色录像| 黄色成人在线中文字幕| 欧美专区第八页一区在线播放 | 女生自摸在线观看一区二区三区| 亚洲午夜在线视频福利| 天天射夜夜操狠狠干| 中文字幕,亚洲人妻| 黄工厂精品视频在线观看| 亚洲激情唯美亚洲激情图片| 亚洲午夜伦理视频在线| 亚洲变态另类色图天堂网| aaa久久久久久久久| 亚洲成高清a人片在线观看| 超黄超污网站在线观看| 在线制服丝袜中文字幕| 在线观看国产网站资源| 色综合久久久久久久久中文| 青青青青视频在线播放| 午夜福利人人妻人人澡人人爽| 绝色少妇高潮3在线观看| 亚洲精品中文字幕下载| 久久三久久三久久三久久| 激情综合治理六月婷婷| 亚洲最大黄了色网站| 大胸性感美女羞爽操逼毛片| 亚洲伊人久久精品影院一美女洗澡| 1769国产精品视频免费观看| 国产福利在线视频一区| 国产污污污污网站在线| 18禁污污污app下载| 亚洲久久午夜av一区二区| 亚洲av自拍天堂网| 中文字幕人妻一区二区视频| 国产av国片精品一区二区| 国产日本欧美亚洲精品视| 日本福利午夜电影在线观看| 午夜青青草原网在线观看| 日本熟妇喷水xxx| 天天摸天天亲天天舔天天操天天爽| 中文字幕第三十八页久久 | 在线观看亚洲人成免费网址| 啊用力插好舒服视频| 不卡一区一区三区在线| 2022国产综合在线干| 狠狠躁夜夜躁人人爽天天久天啪| 91极品大一女神正在播放| 在线免费观看99视频| 深田咏美亚洲一区二区| 国产精彩对白一区二区三区 | 日韩视频一区二区免费观看| 超黄超污网站在线观看| 国产女人被做到高潮免费视频| 黄色大片免费观看网站| 2012中文字幕在线高清| 亚洲免费国产在线日韩| 欧美日韩高清午夜蜜桃大香蕉| 国产亚洲欧美另类在线观看| lutube在线成人免费看| 无码精品一区二区三区人| 国产在线自在拍91国语自产精品| 好吊操视频这里只有精品| 国产亚洲欧美45p| 狍和女人的王色毛片| 2020中文字幕在线播放| 操的小逼流水的文章| 久久亚洲天堂中文对白| 亚洲嫩模一区二区三区| 大香蕉福利在线观看| 免费看国产av网站| 国产福利在线视频一区| 日本免费午夜视频网站| 国产午夜激情福利小视频在线| 国产精品久久久黄网站| 精品人人人妻人人玩日产欧| 欧美色婷婷综合在线| 欧美日本在线观看一区二区| 蜜臀av久久久久蜜臀av麻豆| 久久久久久久久久久久久97| 直接观看免费黄网站| 91高清成人在线视频| 日辽宁老肥女在线观看视频| 91传媒一区二区三区| 4个黑人操素人视频网站精品91| 国产V亚洲V天堂无码欠欠| 亚洲一区二区三区精品视频在线| 亚洲欧洲一区二区在线观看| 中文字幕人妻被公上司喝醉在线| 亚洲一级美女啪啪啪| 91传媒一区二区三区| 粉嫩欧美美人妻小视频| 偷青青国产精品青青在线观看| 精品国产午夜视频一区二区| 中文字幕之无码色多多| 欧美精品中文字幕久久二区| 日韩午夜福利精品试看| 精品人人人妻人人玩日产欧| 精品高跟鞋丝袜一区二区| 99久久99一区二区三区| 51国产偷自视频在线播放| 青青青青青青青青青青草青青| 女同久久精品秋霞网| 在线视频这里只有精品自拍| 亚洲一区二区三区av网站| 在线免费观看日本伦理| 日韩美女搞黄视频免费| 亚洲图片欧美校园春色| 99精品一区二区三区的区| 国产V亚洲V天堂无码欠欠| 亚洲青青操骚货在线视频| 中文字幕人妻熟女在线电影| 亚洲公开视频在线观看| 久久精品36亚洲精品束缚| 91福利在线视频免费观看| 97人人妻人人澡人人爽人人精品| 国产亚洲国产av网站在线| 亚洲卡1卡2卡三卡四老狼| 狍和女人的王色毛片| 91she九色精品国产| 国产成人精品久久二区91| 中文字幕一区二区三区人妻大片 | 亚洲av无硬久久精品蜜桃| 天天射夜夜操综合网| 国产精品国产三级麻豆| 亚洲av色香蕉一区二区三区| 亚洲人人妻一区二区三区| 国产精品久久久久久久女人18| 中国黄色av一级片| 老司机在线精品福利视频| 人妻少妇性色欲欧美日韩| 91天堂精品一区二区| 国产超码片内射在线| 欧美viboss性丰满| 首之国产AV医生和护士小芳| 99精品一区二区三区的区| 国产精品国色综合久久| 日韩欧美亚洲熟女人妻| 93精品视频在线观看| 久久香蕉国产免费天天| 午夜精品久久久久麻豆影视| 动漫av网站18禁| 真实国模和老外性视频| 大香蕉福利在线观看| 国产无遮挡裸体免费直播视频| 中文亚洲欧美日韩无线码| 亚洲国产在人线放午夜| 99热这里只有国产精品6| 久久机热/这里只有| 国产午夜激情福利小视频在线| 国产成人精品午夜福利训2021| 中文字幕 人妻精品| 精品av国产一区二区三区四区 | 在线视频自拍第三页| 99的爱精品免费视频| 国际av大片在线免费观看| 欧美精品欧美极品欧美视频| 黄色片年轻人在线观看| 日本真人性生活视频免费看| 成人资源在线观看免费官网| 夜夜躁狠狠躁日日躁麻豆内射 | 欧美老鸡巴日小嫩逼| 综合国产成人在线观看| 岛国av高清在线成人在线| 国产精品久久久久久久久福交| 天天射,天天操,天天说| 人妻av无码专区久久绿巨人| 人妻3p真实偷拍一二区| 可以免费看的www视频你懂的| 午夜91一区二区三区| 熟女在线视频一区二区三区| 一本一本久久a久久精品综合不卡| 东京干手机福利视频| 国产精品久久9999| 亚洲欧美国产综合777| 果冻传媒av一区二区三区 | 中文字幕人妻被公上司喝醉在线| 成人av电影免费版| 青青草人人妻人人妻| 中文人妻AV久久人妻水| 男人天堂av天天操| 欧亚日韩一区二区三区观看视频| 97国产福利小视频合集| 国产一级麻豆精品免费| 偷拍自拍国产在线视频| 2022精品久久久久久中文字幕| 午夜精彩视频免费一区| 日本精品一区二区三区在线视频。 | 欧美亚洲一二三区蜜臀| 色婷婷久久久久swag精品| 91精品国产91久久自产久强| AV天堂一区二区免费试看| 9色精品视频在线观看| 中文字幕一区二区人妻电影冢本| 国产va精品免费观看| 亚洲免费va在线播放| 99re国产在线精品| 国产一区自拍黄视频免费观看| 男人的网址你懂的亚洲欧洲av| 偷拍自拍视频图片免费| 三级等保密码要求条款| av高潮迭起在线观看| 国产日韩精品一二三区久久久 | 男女之间激情网午夜在线| 东京干手机福利视频| 日韩影片一区二区三区不卡免费| 亚洲一区二区激情在线| 在线制服丝袜中文字幕| 人妻3p真实偷拍一二区| 女同互舔一区二区三区| 中国老熟女偷拍第一页| av手机在线观播放网站| 亚洲国产成人最新资源| 日韩欧美国产精品91| av欧美网站在线观看| 中文字幕一区二 区二三区四区| 少妇一区二区三区久久久| 成年人中文字幕在线观看| 青青操免费日综合视频观看| 少妇露脸深喉口爆吞精| 久草视频在线看免费| 国产精品国产三级国产午| 好吊视频—区二区三区| 国产亚洲视频在线观看| 五十路熟女av天堂| 福利视频一区二区三区筱慧| 换爱交换乱高清大片| 风流唐伯虎电视剧在线观看| 亚洲久久午夜av一区二区| 中文字幕人妻熟女在线电影| 亚洲男人让女人爽的视频| 91人妻精品一区二区久久| 国产使劲操在线播放| 中国熟女@视频91| 人妻凌辱欧美丰满熟妇| 亚洲专区激情在线观看视频| 亚洲美女高潮喷浆视频| 亚洲免费在线视频网站| 男生舔女生逼逼视频| 2020久久躁狠狠躁夜夜躁| av高潮迭起在线观看| 瑟瑟视频在线观看免费视频| 在线观看国产网站资源| 桃色视频在线观看一区二区| 人人爱人人妻人人澡39| gay gay男男瑟瑟在线网站| 国产av一区2区3区| 班长撕开乳罩揉我胸好爽| 久碰精品少妇中文字幕av| japanese五十路熟女熟妇| 国产熟妇人妻ⅹxxxx麻豆| 中文字幕日韩91人妻在线| 日韩av中文在线免费观看| 精品av国产一区二区三区四区| 啊慢点鸡巴太大了啊舒服视频| 国产无遮挡裸体免费直播视频| 午夜精品一区二区三区城中村| 色综合天天综合网国产成人| 91在线视频在线精品3| 日韩激情文学在线视频| 一区二区三区蜜臀在线| 成人性黑人一级av| 国内自拍第一页在线观看| 亚洲熟妇x久久av久久| 丝袜肉丝一区二区三区四区在线| 亚洲偷自拍高清视频| 国产成人无码精品久久久电影| 国产成人精品亚洲男人的天堂| 欧美麻豆av在线播放| 国产一区成人在线观看视频| 国产丰满熟女成人视频| 黑人乱偷人妻中文字幕| 欧美日本国产自视大全| 精品一区二区三四区| 超碰97人人澡人人| 欧美精品一二三视频| 欧美男同性恋69视频| 青青草精品在线视频观看| 午夜在线观看一区视频| 亚洲国产香蕉视频在线播放| 亚洲最大免费在线观看| 欲乱人妻少妇在线视频裸| 热久久只有这里有精品| jul—619中文字幕在线| 夜夜嗨av一区二区三区中文字幕| 色av色婷婷人妻久久久精品高清| 亚洲国产成人av在线一区| 操操网操操伊剧情片中文字幕网 | 五十路老熟女码av| 黄色无码鸡吧操逼视频| 国产精品成人xxxx| 黄色资源视频网站日韩| 麻豆性色视频在线观看| 插逼视频双插洞国产操逼插洞 | 国产第一美女一区二区三区四区| 国内自拍第一页在线观看| 91精品激情五月婷婷在线| 国产欧美日韩在线观看不卡| 亚国产成人精品久久久| 黄网十四区丁香社区激情五月天| 亚洲精品久久视频婷婷| 91精品激情五月婷婷在线| 影音先锋女人av噜噜色| 欧美精品免费aaaaaa| 成熟熟女国产精品一区| 又色又爽又黄的美女裸体| 97人妻人人澡爽人人精品| 亚洲欧美一卡二卡三卡| 国产午夜亚洲精品不卡在线观看| 日本熟妇色熟妇在线观看| 视频二区在线视频观看| 青青青青青操视频在线观看| 成人av免费不卡在线观看| 亚洲综合乱码一区二区| 亚洲在线免费h观看网站| 色综合久久无码中文字幕波多| 亚洲Av无码国产综合色区| 极品粉嫩小泬白浆20p主播| 亚洲国产40页第21页| 91麻豆精品91久久久久同性| 日韩精品中文字幕在线| 在线 中文字幕 一区| 欧美一级色视频美日韩| 国产熟妇人妻ⅹxxxx麻豆| 国产麻豆91在线视频| 中国黄片视频一区91| 和邻居少妇愉情中文字幕| 天天干天天日天天干天天操| av高潮迭起在线观看| 少妇高潮无套内谢麻豆| 视频一区二区三区高清在线| 91综合久久亚洲综合| 日本精品美女在线观看| 天天操夜夜骑日日摸| 国产三级影院在线观看| 亚洲最大黄 嗯色 操 啊| 免费大片在线观看视频网站| 亚洲 清纯 国产com| 青春草视频在线免费播放| 欧美日韩亚洲国产无线码| 激情人妻校园春色亚洲欧美| 免费黄页网站4188| 蜜桃色婷婷久久久福利在线| 天天操夜夜骑日日摸| 9色在线视频免费观看| 国内自拍第一页在线观看| 亚洲日本一区二区三区| 日本午夜福利免费视频| 亚洲熟女综合色一区二区三区四区| 夏目彩春在线中文字幕| 亚洲一区二区三区精品乱码| 91大屁股国产一区二区| 中文字幕中文字幕人妻| 国产又大又黄免费观看| 天天操夜夜操天天操天天操| 九一传媒制片厂视频在线免费观看| 午夜久久久久久久99| 性欧美日本大妈母与子| 人妻丝袜精品中文字幕| 久久久久久久久久一区二区三区| 亚洲激情av一区二区| 成人国产影院在线观看| 一区二区三区在线视频福利| 免费观看理论片完整版| 偷青青国产精品青青在线观看 | 欧美另类z0z变态| 成人av久久精品一区二区| 国产精品免费不卡av| 国产大鸡巴大鸡巴操小骚逼小骚逼| 免费观看丰满少妇做受| 国产男女视频在线播放| 午夜激情高清在线观看| 天天通天天透天天插| 一二三中文乱码亚洲乱码one| 中文字幕奴隷色的舞台50| 国产女人露脸高潮对白视频| 亚洲的电影一区二区三区| 快点插进来操我逼啊视频| av网址在线播放大全| 瑟瑟视频在线观看免费视频| 天天摸天天亲天天舔天天操天天爽| 日本高清撒尿pissing| 日本福利午夜电影在线观看| 国产视频网站一区二区三区| 免费一级特黄特色大片在线观看| 很黄很污很色的午夜网站在线观看| 自拍偷拍日韩欧美亚洲| 国产亚洲天堂天天一区| 久久久制服丝袜中文字幕| 亚洲自拍偷拍精品网| 国产精品福利小视频a| 欧美黑人性暴力猛交喷水| 欧美少妇性一区二区三区| 国产亚洲天堂天天一区| 国内精品在线播放第一页| 黄色资源视频网站日韩| 国产女人露脸高潮对白视频| 热久久只有这里有精品| 亚洲欧美成人综合视频| 极品丝袜一区二区三区| 中文字幕在线永久免费播放| 自拍偷拍亚洲精品第2页| 视频一区 二区 三区 综合| 91麻豆精品91久久久久同性| 亚洲无码一区在线影院| 91精品视频在线观看免费| 91超碰青青中文字幕| 美女视频福利免费看| 天天射,天天操,天天说| 国产高清女主播在线| 亚洲在线一区二区欧美| 美女福利视频网址导航| 亚洲av可乐操首页| 男大肉棒猛烈插女免费视频| 久久永久免费精品人妻专区| 色综合久久无码中文字幕波多| 国产卡一卡二卡三乱码手机| 亚洲福利午夜久久久精品电影网 | 欧美亚洲免费视频观看| 高潮视频在线快速观看国家快速| 国产在线一区二区三区麻酥酥 | 天天干天天日天天干天天操| 国产精品国产三级国产精东| 日韩欧美中文国产在线| 亚洲成人情色电影在线观看| 91中文字幕最新合集| 九色精品视频在线播放| 韩国三级aaaaa高清视频| 精品成人啪啪18免费蜜臀| 久久久久只精品国产三级| 狍和女人的王色毛片| 97超碰国语国产97超碰| 小泽玛利亚视频在线观看| 啊啊啊视频试看人妻| 精品av国产一区二区三区四区 | 国产精品自拍在线视频| 国产在线拍揄自揄视频网站| 91精品国产综合久久久蜜| 日韩欧美高清免费在线| 四虎永久在线精品免费区二区| 欧美亚洲少妇福利视频| 欧美viboss性丰满| 在线免费观看亚洲精品电影| 欧美黄色录像免费看的| 久久精品视频一区二区三区四区 | 4个黑人操素人视频网站精品91 | 换爱交换乱高清大片| av中文字幕电影在线看| 晚上一个人看操B片| 91成人精品亚洲国产| 日本黄色三级高清视频| 中文字幕亚洲中文字幕| 日韩欧美一级aa大片| 东京热男人的av天堂| 91麻豆精品传媒国产黄色片| 青青草原色片网站在线观看| 女生被男生插的视频网站| 91在线视频在线精品3| 青青青国产免费视频| 色婷婷六月亚洲综合香蕉| 伊人日日日草夜夜草| 国产欧美精品免费观看视频| 亚洲熟女女同志女同| 国产欧美精品不卡在线| 国产三级影院在线观看| 蜜桃色婷婷久久久福利在线| 中出中文字幕在线观看 | 成人福利视频免费在线| 东京热男人的av天堂| 亚洲青青操骚货在线视频| 97人妻无码AV碰碰视频| 欧美 亚洲 另类综合| av视屏免费在线播放| 成人国产激情自拍三区| 色婷婷精品大在线观看| 亚洲公开视频在线观看| 大鸡巴后入爆操大屁股美女| 午夜精品福利一区二区三区p | 亚洲伊人色一综合网| 特一级特级黄色网片| 美女福利视频导航网站| 91av中文视频在线| 无套猛戳丰满少妇人妻| 精品欧美一区二区vr在线观看| 人妻少妇av在线观看| 爆乳骚货内射骚货内射在线| 久久久超爽一二三av| 首之国产AV医生和护士小芳| 欧洲欧美日韩国产在线| 美女视频福利免费看| 日韩a级黄色小视频| 国产综合高清在线观看| 日韩人妻在线视频免费| 亚洲av男人的天堂你懂的| 可以在线观看的av中文字幕 | 亚洲视频在线观看高清| 久久香蕉国产免费天天| 男人的天堂av日韩亚洲| 中文字幕高清在线免费播放| 老鸭窝在线观看一区| 欧美日韩中文字幕欧美| 99热国产精品666| 亚洲区欧美区另类最新章节| 欧美综合婷婷欧美综合| 老司机99精品视频在线观看| 日韩熟女av天堂系列| 久久一区二区三区人妻欧美| 日韩a级黄色小视频| 黄色在线观看免费观看在线| 久久久人妻一区二区| 欧美精产国品一二三产品价格 | 大鸡八强奸视频在线观看| 国产亚洲精品视频合集| 国产麻豆91在线视频| 极品粉嫩小泬白浆20p主播 | 亚洲在线免费h观看网站| 馒头大胆亚洲一区二区| 91啪国自产中文字幕在线| 狠狠鲁狠狠操天天晚上干干| 国产精品视频欧美一区二区| 在线免费观看国产精品黄色| 国产亚洲精品视频合集| 国产精品污污污久久| 91中文字幕免费在线观看| 激情五月婷婷免费视频| 97青青青手机在线视频 | 日本黄色特一级视频| 早川濑里奈av黑人番号| 色伦色伦777国产精品| 亚洲国产中文字幕啊啊啊不行了| 人妻丝袜精品中文字幕| 精品国产成人亚洲午夜| 韩国亚洲欧美超一级在线播放视频 | 人妻丰满熟妇综合网| 亚洲中文精品人人免费| yellow在线播放av啊啊啊| 动漫精品视频在线观看| 日韩美女精品视频在线观看网站| 人人妻人人爱人人草| 91国产资源在线视频| 日韩三级黄色片网站| 中文字幕人妻av在线观看| 在线网站你懂得老司机| 成年人啪啪视频在线观看| 日韩人妻xxxxx| 久久久久久久久久一区二区三区| 亚洲欧美综合另类13p| 亚洲成人黄色一区二区三区| 天天干天天操天天玩天天射| 人妻熟女中文字幕aⅴ在线| 一级黄片大鸡巴插入美女| 亚洲免费av在线视频| av网址在线播放大全| 亚洲男人的天堂a在线| 北条麻妃高跟丝袜啪啪| 久久久久久久久久久免费女人| 久久久麻豆精亚洲av麻花| 国产又粗又硬又猛的毛片视频 | 换爱交换乱高清大片| 在线可以看的视频你懂的 | 大香蕉大香蕉在线看| lutube在线成人免费看| 午夜精品一区二区三区4| okirakuhuhu在线观看| 久久机热/这里只有| 国产免费高清视频视频| 亚洲偷自拍高清视频| 激情色图一区二区三区| 欧美日韩高清午夜蜜桃大香蕉| 欧美特色aaa大片| 精品久久久久久久久久久久人妻| 亚洲福利午夜久久久精品电影网| 视频一区二区综合精品| 国内资源最丰富的网站| 青娱乐蜜桃臀av色| 午夜国产免费福利av| 日本脱亚入欧是指什么| 一级黄色av在线观看| 久草视频在线看免费| 青青草原网站在线观看| 3344免费偷拍视频| 91桃色成人网络在线观看| 日本后入视频在线观看 | 青娱乐蜜桃臀av色| 国产aⅴ一线在线观看| av天堂加勒比在线| 日韩在线中文字幕色| 91久久精品色伊人6882| 欧美少妇性一区二区三区| 在线视频免费观看网| 懂色av之国产精品| 视频一区 视频二区 视频| 日韩美女综合中文字幕pp| 一色桃子久久精品亚洲| 亚洲午夜在线视频福利| 中文字幕在线第一页成人 | 国产高清在线观看1区2区| 亚洲女人的天堂av| 亚洲中文精品字幕在线观看| 亚洲成人国产综合一区| 国产女孩喷水在线观看| 可以在线观看的av中文字幕| gav成人免费播放| 中文字幕中文字幕人妻| 91人妻人人做人人爽在线| www,久久久,com| 一区二区三区另类在线| 丝袜美腿欧美另类 中文字幕| 无套猛戳丰满少妇人妻| 国产欧美日韩第三页| 成人动漫大肉棒插进去视频| 自拍偷区二区三区麻豆| av手机在线免费观看日韩av| 亚洲码av无色中文| 日本黄在免费看视频| 亚洲中文字幕人妻一区| mm131美女午夜爽爽爽| 国产又色又刺激在线视频 | 中文字幕高清在线免费播放| 熟女少妇激情五十路| 最新日韩av传媒在线| 在线免费观看靠比视频的网站| 亚洲麻豆一区二区三区| 亚洲欧美福利在线观看| 天天日天天透天天操| av日韩在线观看大全| 深田咏美亚洲一区二区| 把腿张开让我插进去视频| 2022国产综合在线干| 国产精选一区在线播放| 视频二区在线视频观看| 日本a级视频老女人| 欧美一区二区三区乱码在线播放| 亚国产成人精品久久久| 免费观看理论片完整版| 亚洲综合另类精品小说| 曰本无码人妻丰满熟妇啪啪| av一区二区三区人妻| 国产亚洲国产av网站在线| 后入美女人妻高清在线| 男生舔女生逼逼的视频| 在线观看欧美黄片一区二区三区| 国产精品国产三级麻豆| 久久99久久99精品影院| 欲满人妻中文字幕在线| 欧美精产国品一二三区| 欧美性感尤物人妻在线免费看| 黄色成人在线中文字幕| 亚洲成人激情视频免费观看了| 偷偷玩弄新婚人妻h视频| 动漫精品视频在线观看| 粉嫩小穴流水视频在线观看| 午夜激情久久不卡一区二区| 中文字幕免费在线免费| 78色精品一区二区三区| 人人妻人人人操人人人爽| 红桃av成人在线观看| 护士小嫩嫩又紧又爽20p| 国产日韩精品电影7777| 亚洲成人激情av在线| 插小穴高清无码中文字幕| 三级黄色亚洲成人av| 直接观看免费黄网站| 在线观看欧美黄片一区二区三区| 国产av一区2区3区| 啊啊啊想要被插进去视频| 免费在线福利小视频| 亚洲激情av一区二区| 色狠狠av线不卡香蕉一区二区| av视网站在线观看| 亚洲免费在线视频网站| 91老熟女连续高潮对白| 久久国产精品精品美女| 欧美性受xx黑人性猛交| 91九色porny国产蝌蚪视频| 亚洲av在线观看尤物| 九色视频在线观看免费| 春色激情网欧美成人| 夜色撩人久久7777| 亚洲一区二区三区偷拍女厕91 | av中文字幕网址在线| 亚洲激情偷拍一区二区| 欧美成人黄片一区二区三区 | 日韩北条麻妃一区在线| 欧美一区二区三区乱码在线播放| 蜜桃精品久久久一区二区| 农村胖女人操逼视频| 天堂女人av一区二区| 大香蕉伊人中文字幕| 早川濑里奈av黑人番号| 中文字幕 码 在线视频| 特级无码毛片免费视频播放| 日本三极片视频网站观看| 天天艹天天干天天操| 国产麻豆91在线视频| 巨乳人妻日下部加奈被邻居中出| 大屁股肉感人妻中文字幕在线| 国产va在线观看精品| 成人动漫大肉棒插进去视频| 91免费黄片可看视频| 成人sm视频在线观看| 免费在线观看污污视频网站| 欧美日韩国产一区二区三区三州| av在线播放国产不卡| 日本脱亚入欧是指什么| 五月天色婷婷在线观看视频免费| 天天干天天日天天谢综合156| 狠狠操狠狠操免费视频| 欧洲精品第一页欧洲精品亚洲| 专门看国产熟妇的网站| 精品一线二线三线日本| 亚洲av日韩高清hd| 久久久久久九九99精品| 天天日天天日天天射天天干| 亚洲免费成人a v| 久久久久只精品国产三级| 综合色区亚洲熟妇shxstz| 久久综合老鸭窝色综合久久| 亚洲视频乱码在线观看| 日本少妇高清视频xxxxx| 青青青爽视频在线播放| 亚洲一区二区三区偷拍女厕91 | 色伦色伦777国产精品| 特级欧美插插插插插bbbbb| 国产又粗又猛又爽又黄的视频在线 | 亚洲精品国产久久久久久| 国产av自拍偷拍盛宴| 男人的天堂在线黄色| 欧洲精品第一页欧洲精品亚洲| 午夜久久久久久久99| 天码人妻一区二区三区在线看| 国产无遮挡裸体免费直播视频| 国产精品人妻一区二区三区网站| 噜噜色噜噜噜久色超碰| 国产女人被做到高潮免费视频 | 欧洲黄页网免费观看| AV天堂一区二区免费试看| 日本精品美女在线观看| 天堂av在线播放免费| 亚洲精品欧美日韩在线播放| 亚洲午夜福利中文乱码字幕| 天天色天天操天天透| 大肉大捧一进一出好爽在线视频| 亚洲免费va在线播放| 美女被肏内射视频网站| 免费费一级特黄真人片 | 黄片色呦呦视频免费看| 人妻自拍视频中国大陆| 亚洲第一黄色在线观看| 天天日天天添天天爽| 欧美亚洲免费视频观看| 真实国产乱子伦一区二区| 黄片大全在线观看观看| 高潮喷水在线视频观看| 欧美亚洲中文字幕一区二区三区 | 亚洲免费av在线视频| 换爱交换乱高清大片| 插小穴高清无码中文字幕| 亚洲欧美成人综合视频| 在线观看视频 你懂的| 男人天堂av天天操| 亚洲一区二区三区uij| 97小视频人妻一区二区| 大香蕉大香蕉在线有码 av| 最近中文字幕国产在线| 欧美视频不卡一区四区| 亚洲熟女女同志女同| 最新的中文字幕 亚洲| 天堂资源网av中文字幕| 神马午夜在线观看视频| 国产 在线 免费 精品| 欧美日韩一级黄片免费观看| 动漫精品视频在线观看| 最近的中文字幕在线mv视频| 搡老熟女一区二区在线观看| 老司机免费视频网站在线看| 性感美女高潮视频久久久| 久草视频 久草视频2| 精品高潮呻吟久久av| 亚洲精品国产在线电影| 午夜在线观看一区视频| 40道精品招牌菜特色| rct470中文字幕在线| 亚洲欧美激情中文字幕| 日日操综合成人av| chinese国产盗摄一区二区 | 日本少妇高清视频xxxxx | 亚洲av无码成人精品区辽| 亚洲精品乱码久久久久久密桃明| 青青操免费日综合视频观看| 在线亚洲天堂色播av电影| 日本a级视频老女人| 成人精品在线观看视频| 黄色大片男人操女人逼| 亚洲码av无色中文| eeuss鲁片一区二区三区| 337p日本大胆欧美人| 成人蜜臀午夜久久一区| 亚洲精品精品国产综合| 91久久综合男人天堂| 国产午夜亚洲精品麻豆| 天天射夜夜操综合网| 中英文字幕av一区| 最近的中文字幕在线mv视频| 欧美日韩人妻久久精品高清国产| 国产日韩av一区二区在线| 久久三久久三久久三久久| 久久麻豆亚洲精品av| 亚洲国产欧美国产综合在线| av高潮迭起在线观看| 天天干天天爱天天色| 蜜臀av久久久久久久| gogo国模私拍视频| av森泽佳奈在线观看| 成人资源在线观看免费官网| 亚洲av午夜免费观看| 春色激情网欧美成人| 午夜精品一区二区三区4| aⅴ精产国品一二三产品| 5528327男人天堂| 日韩欧美亚洲熟女人妻| 综合激情网激情五月五月婷婷| 激情啪啪啪啪一区二区三区| 直接能看的国产av| 九九视频在线精品播放| 婷婷久久久综合中文字幕| 久久机热/这里只有| 999九九久久久精品| 2022精品久久久久久中文字幕| 在线观看国产网站资源| 日本性感美女视频网站| 888欧美视频在线| 黄片大全在线观看观看| 欧美亚洲自偷自拍 在线| 免费男阳茎伸入女阳道视频| 青春草视频在线免费播放| 国语对白xxxx乱大交| 天天日天天干天天插舔舔| 男人的天堂一区二区在线观看| 一本一本久久a久久精品综合不卡| 成人国产激情自拍三区| 中文字幕国产专区欧美激情| 国产自拍在线观看成人| 丰满的子国产在线观看| 久久精品国产亚洲精品166m| 少妇人妻久久久久视频黄片| 熟女视频一区,二区,三区| 自拍 日韩 欧美激情| 国产黄色片在线收看| 中文字幕第三十八页久久| 国产极品美女久久久久久| sejizz在线视频| 伊人成人综合开心网| 99国内小视频在现欢看| 成年美女黄网站18禁久久| 欧洲黄页网免费观看| caoporn蜜桃视频| 五十路在线观看完整版| 久久丁香花五月天色婷婷| av日韩在线观看大全| 亚洲午夜伦理视频在线| 色综合色综合色综合色| 久久精品美女免费视频| 成人激情文学网人妻| 在线免费观看黄页视频| 97成人免费在线观看网站| 激情色图一区二区三区| 午夜在线观看岛国av,com| 美女操逼免费短视频下载链接| 免费无毒热热热热热热久| 欧美日韩高清午夜蜜桃大香蕉| 成年人黄色片免费网站| 国产福利小视频大全| 中文字母永久播放1区2区3区| av中文字幕在线导航| 欧美成人精品欧美一级黄色| 国产精品国产三级国产午| 嫩草aⅴ一区二区三区| 日韩欧美中文国产在线| 国产成人午夜精品福利| 日韩精品中文字幕播放| 日韩欧美国产精品91| 99精品国自产在线人| 国产又粗又硬又大视频| 美女被肏内射视频网站| 亚洲伊人久久精品影院一美女洗澡| 国产第一美女一区二区三区四区| 9久在线视频只有精品| 性色蜜臀av一区二区三区| 亚洲国产免费av一区二区三区| huangse网站在线观看| 日韩少妇人妻精品无码专区| 亚洲专区激情在线观看视频| 可以免费看的www视频你懂的| 日韩人妻丝袜中文字幕| 沙月文乃人妻侵犯中文字幕在线| 亚洲中文字字幕乱码| 激情综合治理六月婷婷| 100%美女蜜桃视频| 早川濑里奈av黑人番号| 欧美怡红院视频在线观看| 国产品国产三级国产普通话三级| 欧美一区二区三区在线资源 | 亚洲精品ww久久久久久| 日本18禁久久久久久| 国产福利小视频大全| 成人色综合中文字幕| 午夜在线观看一区视频| 亚洲欧美激情中文字幕| 国产精品久久9999| 视频久久久久久久人妻| 视频二区在线视频观看| 久久永久免费精品人妻专区| 国产精品女邻居小骚货| 不卡日韩av在线观看| 亚洲欧美福利在线观看| 日韩熟女系列一区二区三区| 精品日产卡一卡二卡国色天香| 操人妻嗷嗷叫视频一区二区| 97人人模人人爽人人喊| 漂亮 人妻被中出中文| 国产真实乱子伦a视频| 高潮喷水在线视频观看| 国产麻豆剧果冻传媒app| 国产一线二线三线的区别在哪| 日本韩国免费一区二区三区视频| 91极品大一女神正在播放| 国产黄色片蝌蚪九色91| 亚洲国产精品美女在线观看| 国产av福利网址大全| 日韩美av高清在线| 成人网18免费视频版国产| 中文字幕在线乱码一区二区| av在线资源中文字幕| 亚洲一区久久免费视频| 美女福利视频网址导航| 少妇人妻100系列| 天天日天天天天天天天天天天| 亚洲色偷偷综合亚洲AV伊人| 亚洲午夜伦理视频在线| 五十路熟女av天堂| 亚洲最大免费在线观看| 亚洲熟女久久久36d| 一本一本久久a久久精品综合不卡| 日本脱亚入欧是指什么| 2021久久免费视频| 一区二区三区四区中文| 欧美性感尤物人妻在线免费看| 动漫美女的小穴视频| 成人国产影院在线观看| 亚洲一级av无码一级久久精品| 岛国黄色大片在线观看| 国产精品一区二区三区蜜臀av| 国产在线免费观看成人| 午夜精品福利一区二区三区p| 97精品人妻一区二区三区精品| 丝袜亚洲另类欧美变态| 亚洲综合自拍视频一区| 亚洲高清视频在线不卡| 亚洲另类综合一区小说| 啪啪啪啪啪啪啪免费视频| 亚洲av黄色在线网站| av天堂中文免费在线| 欧美成人精品在线观看| av网址在线播放大全| 五月天色婷婷在线观看视频免费| 成人免费公开视频无毒| 亚洲特黄aaaa片| 无忧传媒在线观看视频| 亚洲国产欧美一区二区三区久久| 亚洲av日韩av第一区二区三区| 亚洲色偷偷综合亚洲AV伊人| 成年午夜影片国产片| 国产成人自拍视频在线免费观看| 欧美亚洲免费视频观看| 国产美女一区在线观看| 2021年国产精品自拍| 中出中文字幕在线观看| 亚洲欧美一卡二卡三卡| 91亚洲精品干熟女蜜桃频道| 一区二区三区欧美日韩高清播放| 91 亚洲视频在线观看| 精品91高清在线观看| 五色婷婷综合狠狠爱| 在线不卡成人黄色精品| 午夜精品福利91av| 超pen在线观看视频公开97| jiujiure精品视频在线| 日韩a级黄色小视频| 五十路av熟女松本翔子| 久久精品国产亚洲精品166m| 亚洲欧美一区二区三区爱爱动图| 在线可以看的视频你懂的 | 一区二区三区欧美日韩高清播放| 久久久久久久99精品| 亚洲欧美国产综合777| 97年大学生大白天操逼| 国产女人露脸高潮对白视频| 午夜在线观看一区视频| 成人高清在线观看视频| 黄片色呦呦视频免费看| 狠狠地躁夜夜躁日日躁| 欧美麻豆av在线播放| 免费啪啪啪在线观看视频| 国产精品黄色的av| 国产老熟女伦老熟妇ⅹ| 国产中文字幕四区在线观看| 中文字幕在线永久免费播放| 一区二区三区四区视频| 精品人妻每日一部精品| 久久久精品国产亚洲AV一| 中文字幕av一区在线观看| 国产一区二区在线欧美| 999久久久久999| 美女福利视频导航网站 | yellow在线播放av啊啊啊| 国产极品美女久久久久久| 亚洲av男人天堂久久| 免费啪啪啪在线观看视频| 日本少妇的秘密免费视频| 黄色资源视频网站日韩| nagger可以指黑人吗| 无码精品一区二区三区人| 中文字幕av一区在线观看| 精品91自产拍在线观看一区| 亚洲福利天堂久久久久久| 好太好爽好想要免费| 免费高清自慰一区二区三区网站| 美洲精品一二三产区区别 | 一区二区三区激情在线| 少妇深喉口爆吞精韩国| 91破解版永久免费| 绝色少妇高潮3在线观看| 亚洲 中文 自拍 无码| 久久久久久久精品老熟妇| 国产一区自拍黄视频免费观看| 日本一二三区不卡无|