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

JS圖片壓縮的實(shí)現(xiàn)思路

開發(fā) 前端
涉及到 JS 的圖片壓縮,我的想法是需要用到 Canvas 的繪圖能力,通過調(diào)整圖片的分辨率或者繪圖質(zhì)量來達(dá)到圖片壓縮的效果。

前言

說起圖片壓縮,大家想到的或者平時(shí)用到的很多工具都可以實(shí)現(xiàn),例如,客戶端類的有圖片壓縮工具 PPDuck3, JS 實(shí)現(xiàn)類的有插件 compression.js ,亦或是在線處理類的 OSS 上傳,文件上傳后,在訪問文件時(shí)中也有圖片的壓縮配置選項(xiàng),不過,能不能自己擼一套  JS 實(shí)現(xiàn)的圖片壓縮代碼呢?當(dāng)然可以,那我們先來理一下思路。

壓縮思路

涉及到 JS 的圖片壓縮,我的想法是需要用到 Canvas 的繪圖能力,通過調(diào)整圖片的分辨率或者繪圖質(zhì)量來達(dá)到圖片壓縮的效果,實(shí)現(xiàn)思路如下:

  •  獲取上傳 Input 中的圖片對(duì)象 File
  •  將圖片轉(zhuǎn)換成 base64 格式
  •  base64 編碼的圖片通過 Canvas 轉(zhuǎn)換壓縮,這里會(huì)用到的 Canvas 的 drawImage 以及 toDataURL 這兩個(gè) Api,一個(gè)調(diào)節(jié)圖片的分辨率的,一個(gè)是調(diào)節(jié)圖片壓縮質(zhì)量并且輸出的,后續(xù)會(huì)有詳細(xì)介紹
  •  轉(zhuǎn)換后的圖片生成對(duì)應(yīng)的新圖片,然后輸出

優(yōu)缺點(diǎn)介紹

不過 Canvas 壓縮的方式也有著自己的優(yōu)缺點(diǎn):

  •  優(yōu)點(diǎn):實(shí)現(xiàn)簡單,參數(shù)可以配置化,自定義圖片的尺寸,指定區(qū)域裁剪等等。
  •  缺點(diǎn):只有 jpeg 、webp 支持原圖尺寸下圖片質(zhì)量的調(diào)整來達(dá)到壓縮圖片的效果,其他圖片格式,僅能通過調(diào)節(jié)尺寸來實(shí)現(xiàn)

代碼實(shí)現(xiàn) 

  1. <template>  
  2.   <div class="container">  
  3.     <input type="file" id="input-img" @change="compress" />  
  4.     <a :download="fileName" :href="compressImg" >普通下載</a>  
  5.     <button @click="downloadImg">兼容 IE 下載</button>  
  6.     <div>  
  7.       <img :src="compressImg" />  
  8.     </div>  
  9.   </div>  
  10. </template>  
  11. <script>  
  12. export default {  
  13.   name: 'compress',  
  14.   data: function() {  
  15.     return {  
  16.       compressImg: null,  
  17.       fileName: null,  
  18.     };  
  19.   },  
  20.   components: {},  
  21.   methods: {  
  22.     compress() {  
  23.       // 獲取文件對(duì)象  
  24.       const fileObj = document.querySelector('#input-img').files[0];  
  25.       // 獲取文件名稱,后續(xù)下載重命名  
  26.       this.fileName = `${new Date().getTime()}-${fileObj.name}`;  
  27.       // 獲取文件后綴名  
  28.       const fileNames = fileObj.name.split('.');  
  29.       const type = fileNames[fileNames.length-1];  
  30.       // 壓縮圖片  
  31.       this.handleCompressImage(fileObj, type);  
  32.     },  
  33.     handleCompressImage(img, type) {  
  34.       const vm = this 
  35.       let reader = new FileReader();  
  36.       // 讀取文件  
  37.       reader.readAsDataURL(img);  
  38.       reader.onload = function(e) {  
  39.         let image = new Image(); //新建一個(gè)img標(biāo)簽  
  40.         image.src = e.target.result;  
  41.         image.onload = function() { 
  42.            let canvas = document.createElement('canvas');  
  43.           let context = canvas.getContext('2d');  
  44.           // 定義 canvas 大小,也就是壓縮后下載的圖片大小  
  45.           let imageimageWidth = image.width; //壓縮后圖片的大小  
  46.           let imageimageHeight = image.height;  
  47.           canvas.width = imageWidth 
  48.           canvas.height = imageHeight 
  49.            // 圖片不壓縮,全部加載展示  
  50.           context.drawImage(image, 0, 0);  
  51.           // 圖片按壓縮尺寸載入  
  52.           // let imageWidth = 500; //壓縮后圖片的大小  
  53.           // let imageHeight = 200 
  54.           // context.drawImage(image, 0, 0, 500, 200);  
  55.           // 圖片去截取指定位置載入  
  56.           // context.drawImage(image,100, 100, 100, 100, 0, 0, imageWidth, imageHeight);  
  57.           vm.compressImg = canvas.toDataURL(`image/${type}`);  
  58.         };  
  59.       };  
  60.     },  
  61.     // base64 圖片轉(zhuǎn) blob 后下載  
  62.     downloadImg() {  
  63.       let parts = this.compressImg.split(';base64,');  
  64.       let contentType = parts[0].split(':')[1];  
  65.       let raw = window.atob(parts[1]);  
  66.       let rawrawLength = raw.length;  
  67.       let uInt8Array = new Uint8Array(rawLength);  
  68.       for(let i = 0; i < rawLength; ++i) {  
  69.         uInt8Array[i] = raw.charCodeAt(i);  
  70.       }  
  71.       const blob = new Blob([uInt8Array], {type: contentType});  
  72.       this.compressImg = URL.createObjectURL(blob);  
  73.       if (window.navigator.msSaveOrOpenBlob) {  
  74.         // 兼容 ie 的下載方式  
  75.         window.navigator.msSaveOrOpenBlob(blob, this.fileName);  
  76.       }else{  
  77.         const a = document.createElement('a');  
  78.         a.href = this.compressImg;  
  79.         a.setAttribute('download', this.fileName);  
  80.         a.click();  
  81.       }  
  82.     },  
  83.   }  
  84. };  
  85. </script> 

上面的代碼是可以直接拿來看效果的,不喜歡用 Vue 的也可以把代碼稍微調(diào)整一下,下面開始具體分解一下代碼的實(shí)現(xiàn)思路

Input 上傳 File 處理

將 File 對(duì)象通過 FileReader 的 readAsDataURL 方法轉(zhuǎn)換為URL格式的字符串(base64 編碼) 

  1. const fileObj = document.querySelector('#input-img').files[0];  
  2. let reader = new FileReader();  
  3. // 讀取文件  
  4. reader.readAsDataURL(fileObj); 

Canvas 處理 File 對(duì)象

建立一個(gè) Image 對(duì)象,一個(gè) canvas 畫布,設(shè)定自己想要下載的圖片尺寸,調(diào)用 drawImage 方法在 canvas 中繪制上傳的圖片 

  1. let image = new Image(); //新建一個(gè)img標(biāo)簽  
  2. image.src = e.target.result;  
  3. let canvas = document.createElement('canvas');  
  4. let context = canvas.getContext('2d');  
  5. context.drawImage(image, 0, 0); 

Api 解析:drawImage 

  1. context.drawImage(img, sx, sy, sWidth, sHeight, dx, dy, dWidth, dHeight); 

img

就是圖片對(duì)象,可以是頁面上獲取的 DOM 對(duì)象,也可以是虛擬 DOM 中的圖片對(duì)象。

dx、dy、dWidth、dHeight

表示在 canvas 畫布上規(guī)劃出一片區(qū)域用來放置圖片,dx, dy 為繪圖位置在 Canvas 元素的 X 軸、Y 軸坐標(biāo),dWidth, dHeight 指在 Canvas 元素上繪制圖像的寬度和高度(如果不說明, 在繪制時(shí)圖片的寬度和高度不會(huì)縮放)。

sx、sy、swidth、sheight

這 4 個(gè)參數(shù)是用來裁剪源圖片的,表示圖片在 canvas 畫布上顯示的大小和位置。sx, sy 表示在源圖片上裁剪位置的 X 軸、Y 軸坐標(biāo),然后以 swidth, sheight 尺寸來選擇一個(gè)區(qū)域范圍,裁剪出來的圖片作為最終在 Canvas 上顯示的圖片內(nèi)容( swidth, sheight 不說明的情況下,整個(gè)矩形(裁剪)從坐標(biāo)的 sx 和 sy 開始,到圖片的右下角結(jié)束)。

以下為圖片繪制的實(shí)例: 

  1. context.drawImage(image, 0, 0, 100, 100);  
  2. context.drawImage(image, 300, 300, 200, 200);  
  3. context.drawImage(image, 0, 100, 150, 150, 300, 0, 150, 150); 

Api 中奇怪之處在于,sx、sy、swidth、sheight 為選填參數(shù),但位置在 dx、dy、dWidth、dHeight 之前。

Canvas 輸出圖片

調(diào)用 canvas 的 toDataURL 方法可以輸出 base64 格式的圖片。 

  1. canvas.toDataURL(`image/${type}`); 

Api 解析:toDataURL 

  1. canvas.toDataURL(type, encoderOptions); 

type 可選

圖片格式,默認(rèn)為 image/png。

encoderOptions 可選

在指定圖片格式為 image/jpeg 或 image/webp 的情況下,可以從 0 到 1 的區(qū)間內(nèi)選擇圖片的質(zhì)量。如果超出取值范圍,將會(huì)使用默認(rèn)值 0.92。其他參數(shù)會(huì)被忽略。

a 標(biāo)簽的下載

調(diào)用 <a> 標(biāo)簽的 download 屬性,即可完成圖片的下載。

Api 解析:download 

  1. // href 下載必填  
  2. <a download="filename" href="href"> 下載 </a> 

filename

選填,規(guī)定作為文件名來使用的文本。

href

文件的下載地址。

非主流瀏覽器下載處理

到此可以解決 Chroma 、 Firefox 和 Safari(自測(cè)支持) 瀏覽器的下載功能,因?yàn)?IE 等瀏覽器不支持 download 屬性,所以需要進(jìn)行其他方式的下載,也就有了代碼中的后續(xù)內(nèi)容 

  1. // base64 圖片轉(zhuǎn) blob 后下載  
  2. downloadImg() {  
  3.   let parts = this.compressImg.split(';base64,');  
  4.   let contentType = parts[0].split(':')[1];  
  5.   let raw = window.atob(parts[1]);  
  6.   let rawrawLength = raw.length;  
  7.   let uInt8Array = new Uint8Array(rawLength);  
  8.   for(let i = 0; i < rawLength; ++i) {  
  9.     uInt8Array[i] = raw.charCodeAt(i);  
  10.   }  
  11.   const blob = new Blob([uInt8Array], {type: contentType});  
  12.   this.compressImg = URL.createObjectURL(blob);  
  13.   if (window.navigator.msSaveOrOpenBlob) {  
  14.     // 兼容 ie 的下載方式  
  15.     window.navigator.msSaveOrOpenBlob(blob, this.fileName);  
  16.   }else{  
  17.     const a = document.createElement('a');  
  18.     a.href = this.compressImg;  
  19.     a.setAttribute('download', this.fileName);  
  20.     a.click();  
  21.   }  
  •  將之前 canvas 生成的 base64 數(shù)據(jù)拆分后,通過 atob 方法解碼
  •  將解碼后的數(shù)據(jù)轉(zhuǎn)換成 Uint8Array 格式的無符號(hào)整形數(shù)組
  •  轉(zhuǎn)換后的數(shù)組來生成一個(gè) Blob 數(shù)據(jù)對(duì)象,通過 URL.createObjectURL(blob) 來生成一個(gè)臨時(shí)的 DOM 對(duì)象
  •  之后 IE 類瀏覽器可以調(diào)用 window.navigator.msSaveOrOpenBlob 方法來執(zhí)行下載,其他瀏覽器也可以繼續(xù)通過 <a> 標(biāo)簽的 download 屬性來進(jìn)行下載

Api 解析:atob

base-64 解碼使用方法是 atob()。 

  1. window.atob(encodedStr) 

encodedStr

必需,是一個(gè)通過 btoa() 方法編碼的字符串,btoa() 是 base64 編碼的使用方法。

Api 解析:Uint8Array 

  1. new Uint8Array(length) 

length

創(chuàng)建初始化為 0 的,包含 length 個(gè)元素的無符號(hào)整型數(shù)組。

Api 解析:Blob

Blob 對(duì)象表示一個(gè)不可變、原始數(shù)據(jù)的類文件對(duì)象。 

  1. // 構(gòu)造函數(shù)允許通過其它對(duì)象創(chuàng)建 Blob 對(duì)象  
  2. new Blob([obj],{type:createType})  

obj

字符串內(nèi)容

createType

要構(gòu)造的類型

兼容性 IE 10 以上

Api 解析:createObjectURL

靜態(tài)方法會(huì)創(chuàng)建一個(gè) DOMString。 

  1. objectURL = URL.createObjectURL(object); 

object

用于創(chuàng)建 URL 的 File 對(duì)象、Blob 對(duì)象或者 MediaSource 對(duì)象。

Api 解析:window.navigator 

  1. // 官方已不建議使用的文件下載方式,僅針對(duì) ie 且兼容性 10 以上  
  2. // msSaveBlob 僅提供下載  
  3. // msSaveOrOpenBlob 支持下載和打開  
  4. window.navigator.msSaveOrOpenBlob(blob, fileName); 

blob

要下載的 blob 對(duì)象

fileName

下載后命名的文件名稱。

總結(jié)

本文僅針對(duì)圖片壓縮介紹了一些思路,簡單的使用場(chǎng)景可能如下介紹,當(dāng)然也會(huì)引申出來更多的使用場(chǎng)景,這些還有待大家一起挖掘。

  •  上傳存儲(chǔ)圖片如果需要對(duì)文件大小格式有要求的,可以統(tǒng)一壓縮處理圖片
  •  前臺(tái)頁面想要編輯圖片,可以在 Canvas 處理圖片的時(shí)候,加一些其他邏輯,例如添加文字,剪裁,拼圖等等操作

當(dāng)然溫馨提示:因部分接口有 IE 兼容性問題,IE 瀏覽器方面,僅能支持 IE 10 以上版本進(jìn)行下載。

 

 

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

2016-11-02 18:43:02

javascripthtml5vue.js

2020-10-20 11:12:11

Nodejs

2024-07-04 08:26:12

AndroidJPEG圖片

2024-04-19 08:31:40

Android屬性讀取

2022-04-04 16:53:56

Vue.js設(shè)計(jì)框架

2020-08-05 16:09:52

javascript壓縮圖片前端

2015-09-02 11:22:36

JavaScript實(shí)現(xiàn)思路

2022-08-01 12:53:30

前端動(dòng)畫

2022-07-17 11:22:35

前端開發(fā)圖片裁切壓縮上傳

2022-08-08 08:29:55

圖片壓縮前端互聯(lián)網(wǎng)

2023-11-04 12:43:44

前端圖片參數(shù)

2019-12-11 10:50:06

JS圖片前端

2022-08-05 19:27:22

通用API鴻蒙

2018-10-29 09:24:41

Web圖片壓縮網(wǎng)頁加速

2023-01-15 20:28:32

前端圖片壓縮

2020-08-21 09:58:16

谷歌Android工具

2015-05-18 09:59:48

ZooKeeper分布式計(jì)算Hadoop

2025-06-04 08:20:00

Compressor前端開發(fā)

2021-01-04 08:09:58

Node.js磁盤接口

2020-09-16 14:01:10

Vue.js項(xiàng)目語言
點(diǎn)贊
收藏

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

中文字幕日韩在线播放| 中国av一区| 亚洲欧美另类综合偷拍| 国产麻豆日韩| 2019男人天堂| 日韩一二三区| 91福利国产成人精品照片| 一本二本三本亚洲码| 欧美熟妇另类久久久久久不卡| 久久九九99| 理论片在线不卡免费观看| 国模私拍在线观看| 偷拍自拍亚洲| 久久精品一二三| 91亚洲精品在线观看| av资源免费观看| 伊人情人综合网| 国产亚洲欧美aaaa| 无人在线观看的免费高清视频 | 国产无码精品视频| 麻豆精品久久| 在线看不卡av| 欧美 日韩 亚洲 一区| 免费大片在线观看www| 日本欧美一区二区在线观看| 欧美成年人视频网站欧美| 中国女人特级毛片| 亚洲欧美成人vr| 精品999久久久| 日韩欧美中文在线视频| 草民电影神马电影一区二区| 欧美色另类天堂2015| 中国女人做爰视频| 麻豆免费在线视频| 国产精品欧美精品| 天堂一区二区三区 | 欧洲大片精品免费永久看nba| 色国产综合视频| 3d动漫一区二区三区| 七七久久电影网| 亚洲欧美一区二区久久| 91嫩草免费看| 国产理论片在线观看| 日产欧产美韩系列久久99| 国产91|九色| 欧美精品日韩在线| 国产欧美日韩精品一区二区免费| 日韩精品www| 极品白嫩丰满美女无套| 免费成人三级| 一本色道**综合亚洲精品蜜桃冫| 精品视频在线观看一区| 成人影院在线播放| 26uuu精品一区二区| 国产久一道中文一区| 成人无码一区二区三区| 国产91在线看| 国产精品区一区二区三在线播放 | 在线播放日韩专区| 日韩欧美中文在线视频| 成人短视频软件网站大全app| 欧美日韩另类一区| 亚洲制服中文字幕| 日本蜜桃在线观看视频| 精品成人久久av| 成熟老妇女视频| 精品三区视频| 在线不卡欧美精品一区二区三区| 国产永久免费网站| 亚洲天堂中文字幕在线观看| 亚洲高清在线观看| 精品无人区无码乱码毛片国产 | 不卡的av中国片| 久久波多野结衣| 中文字幕欧美在线观看| 日韩av成人高清| 国产日产久久高清欧美一区| 一区二区www| 国产高清亚洲一区| 狠狠色综合一区二区| 国产在线视频网址| 国产精品久久久一本精品| 男人的天堂视频在线| www.51av欧美视频| 欧美在线免费观看亚洲| 一级 黄 色 片一| 欧美重口另类| 精品国产视频在线| 日韩少妇高潮抽搐| 麻豆精品一区二区三区| 亚洲自拍偷拍第一页| 日本高清视频免费观看| 中文天堂在线一区| 亚洲 欧美 综合 另类 中字| 亚洲a∨精品一区二区三区导航| 欧美欧美欧美欧美| 精品无码在线视频| 在线成人直播| 国产成人综合精品在线| xxxx18国产| 中文乱码免费一区二区| 青青青青草视频| 成人豆花视频| 亚洲日韩欧美视频| 久久久久久久久久91| 日韩二区在线观看| 国产综合第一页| 深爱激情五月婷婷| 国产福利精品一区二区| 欧美一区二区在线| 污污视频在线看| 亚洲一区二区视频| 毛葺葺老太做受视频| 成人影院中文字幕| 久久久精品国产| 免费在线黄色网| 日韩av成人高清| 久久久久欧美| 国产91足控脚交在线观看| 欧美日本国产视频| 无码人妻aⅴ一区二区三区69岛| 国产在线成人| 91在线精品视频| 91这里只有精品| 日韩欧美一区二区三区久久| 日批视频免费看| eeuss国产一区二区三区四区| 一本色道久久综合狠狠躁篇怎么玩| 国产在线拍揄自揄拍| 国产一区二区三区四区五区美女| 神马影院一区二区| 欧美大胆性生话| 精品亚洲一区二区三区四区五区 | 日本天堂影院在线视频| 亚洲综合色视频| 中文字幕乱码在线人视频| 日韩伦理一区| 欧美俄罗斯性视频| 国产三级伦理片| 亚洲欧洲无码一区二区三区| 天天爽人人爽夜夜爽| 竹菊久久久久久久| 欧美在线一区二区三区四| 亚洲欧美一区二区三| 婷婷国产在线综合| 变态另类丨国产精品| 欧美中文日韩| 视频一区二区在线| 992tv国产精品成人影院| 国产一区二区三区日韩欧美| 波多野结衣电车| 国产欧美一区二区三区在线看蜜臀 | 国产高清不卡一区| 亚洲黄色网址在线观看| 日韩在线精品强乱中文字幕| 中文字幕一区电影| 一区二区三区www污污污网站| 国产精品日韩成人| 亚洲天堂一区二区在线观看| 中文字幕日韩欧美精品高清在线| 成人在线精品视频| 搞黄网站在线看| 亚洲美女自拍视频| 国产乡下妇女三片| 亚洲免费在线视频一区 二区| 色综合久久久无码中文字幕波多| 在线播放精品| 欧美日韩亚洲综合一区二区三区激情在线| 欧美xxx性| 久久精品电影一区二区| 成人免费观看在线视频| 欧美午夜无遮挡| 精品视频第一页| 国产成人精品午夜视频免费| xxxx18hd亚洲hd捆绑| 精品视频久久| 久久久久久久香蕉网| 熟妇人妻av无码一区二区三区| 日韩欧美国产一区二区| 9.1片黄在线观看| 粉嫩一区二区三区在线看| 欧美色图另类小说| 91蜜臀精品国产自偷在线| 懂色一区二区三区av片| 韩国中文字幕在线| 精品国产乱子伦一区| 波多野结衣影片| 亚洲激情五月婷婷| 韩国女同性做爰三级| 国产成人亚洲精品青草天美| 人妻有码中文字幕| 99久久www免费| 精品九九九九| 自拍偷拍亚洲| 日韩网站免费观看| 亚洲乱码在线观看| 在线日韩一区二区| 激情综合五月网| 国产精品色婷婷| 污片免费在线观看| 国产精品中文有码| 少妇黄色一级片| 国产精品婷婷| 欧美大片免费播放| 久久高清免费| 欧美人与物videos另类| 66精品视频在线观看| 成人激情视频网| 国产精品极品美女在线观看| 久久久久久久久久久91| 蜜桃视频网站在线观看| 亚洲深夜福利网站| 日韩亚洲视频在线观看| 精品国产髙清在线看国产毛片 | 欧美www视频| 中文字幕免费观看视频| 色综合久久久久综合| 日本亚洲色大成网站www久久| 最新日韩在线视频| 美女100%露胸无遮挡| 久久众筹精品私拍模特| 国产av一区二区三区传媒| 精品一区二区三区久久久| 色婷婷综合久久久久中文字幕| 亚洲日本激情| 欧美极品视频一区二区三区| 999久久久久久久久6666| 成人精品在线视频| 国产91在线播放精品| 欧美最猛黑人xxxx黑人猛叫黄| 免费男女羞羞的视频网站在线观看| 精品国内产的精品视频在线观看| freemovies性欧美| 亚洲深夜福利在线| 第一视频专区在线| 在线电影欧美日韩一区二区私密| 青青草在线免费观看| 亚洲韩国日本中文字幕| 日韩一区二区三区在线观看视频| 精品国产乱码久久| 天堂av中文字幕| 日韩国产欧美精品在线| av女名字大全列表| 精品亚洲一区二区| 黄色片视频在线观看| 国产一区二区三区在线| 九九九伊在人线综合| 亚洲天堂免费观看| 高清中文字幕一区二区三区| 中文字幕精品久久久久| 午夜激情视频在线观看| 北条麻妃久久精品| 国产鲁鲁视频在线观看特色| 久久人人爽亚洲精品天堂| 黄网站在线免费看| 欧美成人精品一区二区| 九色91在线| 欧美性一区二区三区| 免费福利视频一区二区三区| 国产福利视频一区| 小说区图片区亚洲| 亚洲自拍偷拍色片视频| eeuss鲁片一区二区三区| 噜噜噜噜噜久久久久久91| 欧美男gay| 国产成人亚洲欧美| 欧美激情99| 亚洲精品在线视频观看| 这里只有精品在线| www国产精品内射老熟女| 99久久夜色精品国产亚洲96 | 97超碰在线资源| 国产精品久久毛片a| 丰满少妇高潮久久三区| 黄色一区二区三区| 中文字幕 欧美激情| 欧美一区二区人人喊爽| 一级黄色av片| 欧美精品tushy高清| 免费av网站在线播放| 亚洲欧美精品在线| av电影在线观看网址| 日韩中文在线观看| 波多野结衣乳巨码无在线观看| 日韩美女福利视频| 中文字幕乱码在线播放| 国产精品人成电影| 最新国产精品精品视频| 日韩免费一区二区三区| 女生裸体视频一区二区三区| a√天堂在线观看| 国产裸体歌舞团一区二区| 95视频在线观看| 国产精品国产三级国产有无不卡| 久久精品国产亚洲av无码娇色| 欧美色区777第一页| 老牛影视av牛牛影视av| 色午夜这里只有精品| 九九色在线视频| 国产日韩一区在线| 自拍欧美一区| 欧美一级视频免费看| 国产美女精品在线| 女人十八毛片嫩草av| 精品成人av一区| 国内老熟妇对白hdxxxx| 伊人久久男人天堂| 91精品论坛| 国产日韩一区二区三区| 一个色综合网| 中国黄色片免费看| 久久久www免费人成精品| 久草视频中文在线| 在线成人av网站| 在线免费观看黄| 国产精品第七影院| 日韩最新在线| 黄色成人在线看| 国产激情一区二区三区四区 | 亚洲午夜电影在线观看| 中文字幕自拍偷拍| 亚洲色图校园春色| 日本免费一区二区三区四区| 国产精品视频入口| 自拍偷拍欧美专区| 日韩成人av免费| 国产精品久久久一区麻豆最新章节| 你懂的国产在线| 亚洲黄色免费三级| a在线视频v视频| 国产伦精品一区二区三毛| 欧美+日本+国产+在线a∨观看| 中文av字幕在线观看| 亚洲国产精品v| 国产成人精品一区二区色戒| 亚洲欧美制服另类日韩| 一本大道色婷婷在线| 久久久久综合一区二区三区| 99精品国产一区二区青青牛奶| 影音先锋资源av| 亚洲五码中文字幕| 神马午夜电影一区二区三区在线观看| 欧美黑人xxx| 激情亚洲另类图片区小说区| 欧美日韩在线一二三| 国产精品久久久亚洲一区| 在线观看国产免费视频| 午夜精品福利一区二区三区av | 中文字幕一区二区人妻痴汉电车| 亚洲午夜未删减在线观看| 色猫猫成人app| 自拍偷拍一区二区三区| 国产麻豆视频精品| 久久黄色免费网站| 亚洲精品www久久久| 亚洲精品mv| 特级西西444www大精品视频| 精品写真视频在线观看| 91日韩中文字幕| 欧美精品一区二区三区在线| 精品众筹模特私拍视频| 狠狠色噜噜狠狠狠狠色吗综合| 老鸭窝91久久精品色噜噜导演| 中文字幕成人动漫| 欧美妇女性影城| 免费在线国产视频| 久久精品人成| 蜜桃免费网站一区二区三区| 欧美黑人性猛交xxx| 日韩av网站电影| 成人黄页网站视频| 91网站在线观看免费| 91亚洲永久精品| 无码人妻精品一区二区三区夜夜嗨 | 欧美日韩精品不卡| 免费在线播放第一区高清av| 国产黄色录像视频| 日韩欧美一区中文| 成人福利视频| 中文字幕精品在线播放| 99亚偷拍自图区亚洲| 中文字幕一区二区人妻| 久久久久久成人| 欧美xxxxx视频| 性久久久久久久久久久| 欧美日韩小视频| 春色校园综合激情亚洲| 亚洲一区二区精品在线观看| 国产精品99久久久久久似苏梦涵| 久久免费激情视频| 久久国产精品久久久久久| 天天操综合520| 奇米视频7777| 中文字幕va一区二区三区| www.成人在线观看| 国产精品日日摸夜夜添夜夜av| 国内精品亚洲| 久久一级免费视频| 精品视频久久久| 成人在线视频你懂的|