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

也許vue+css3做交互特效更簡單

開發(fā) 前端
今天就分享三個簡單的小實例,希望能起到拓展思維的作用,讓大家明白vue+css3應該怎樣開發(fā)交互效果!如果大家有什么好的建議,或者覺得我哪里寫錯了,歡迎指出!
 

1、前言

做項目就難免會開發(fā)交互效果或者特效,而我最近開發(fā)的項目一直在使用vue,開發(fā)技術棧方面,理所當然就使用了vue+css3開發(fā),過程中發(fā)現(xiàn)使用vue+css3開發(fā)特效,和javascript/jquery+css3的思維方式不一樣,但是比javascript/jquery+css3簡單一點點。今天就分享三個簡單的小實例,希望能起到拓展思維的作用,讓大家明白vue+css3應該怎樣開發(fā)交互效果!如果大家有什么好的建議,或者覺得我哪里寫錯了,歡迎指出!

    1.文章上面的代碼,雖然代碼很簡單,不難理解,但是也是建議大家邊寫邊看,這樣不會混亂。

    2.文章所提及的小實例,都是很基礎的,大家可以參照自己的想法進行擴展,或者修改,可能會有意想不到的效果。我寫這類型的文章也是想授人以漁,不是授人以魚!

    3.這幾個實例,摘自我自己的平常練習的項目,代碼已經(jīng)提到github上面了(vue-demos)。歡迎大家star。

2、開場小動畫

運行效果

gif圖模糊效果看著跟實際效果不太一樣!大家注意!

原理分析

說到原理分析,其實也沒什么可以分析的,就是在頁面是下面這個狀態(tài)的時候,把文字替換掉。至于看到字體縮成一團,就是letter-spacing這個css屬性的控制效果。字體模糊就是filter: blur()這個css屬性的控制效果!看到有逐漸的變化,就是css3動畫(animation)的效果

下面簡單分析下,這個動畫的幾個步驟,從下面看到,這個動畫一共8個步驟。

這下就清晰明了了,我們要在下圖這個瞬間開始改變文字,也就是頁面加載了兩秒后,動畫執(zhí)行了兩次后就開始改變文字。然后每隔兩秒改變一次文字,直到最后!

下面給出vue和javascript兩種方式的代碼,看下哪種方式更加的簡單!

vue方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6. </head> 
  7. <style> 
  8.     body{ 
  9.         background: #ccc; 
  10.     } 
  11.     h1 { 
  12.         color: white; 
  13.         text-transform: uppercase; 
  14.         margin-top: 100px; 
  15.         text-align: center; 
  16.         font-size: 6rem; 
  17.         line-height: 1; 
  18.         animation: letterspacing 1s 7 alternate ease-in-out
  19.         display: block; 
  20.         letter-spacing: .5rem; 
  21.     } 
  22.  
  23.     @keyframes letterspacing { 
  24.         0% { 
  25.             letter-spacing: -72px; 
  26.             filter: blur(20px); 
  27.         } 
  28.  
  29.         40% { 
  30.             filter: blur(6px); 
  31.         } 
  32.  
  33.         80% { 
  34.             letter-spacing: 8px; 
  35.             filter: blur(0); 
  36.         } 
  37.     } 
  38. </style> 
  39. <body> 
  40. <div id="text"
  41.     <h1>{{testText}}</h1> 
  42. </div> 
  43. </body> 
  44. <script src="vue.min.js"></script> 
  45. <script type="text/javascript"
  46.     new Vue({ 
  47.         el:'#text'
  48.         data:{ 
  49.             nowIndex:0, 
  50.             testText:'歡迎瀏覽' 
  51.         }, 
  52.         mounted(){ 
  53.             let _this=this; 
  54.             let timer = setInterval(function(){ 
  55.                 _this.nowIndex++; 
  56.                 switch (_this.nowIndex) { 
  57.                     case 1: 
  58.                         _this.testText = '守候的文章'
  59.                         break; 
  60.                     case 2: 
  61.                         _this.testText = '愿您瀏覽愉快'
  62.                         break; 
  63.                     case 3: 
  64.                         _this.testText = '學到知識'
  65.                         break; 
  66.                 } 
  67.                 if (_this.nowIndex > 3) { 
  68.                     setTimeout(() => { 
  69.                         clearInterval(timer); 
  70.                     }, 2000) 
  71.                 } 
  72.             }, 2000) 
  73.         } 
  74.     }) 
  75. </script> 
  76. </html> 

javascript方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6. </head> 
  7. <style> 
  8.     body{ 
  9.         background: #ccc; 
  10.     } 
  11.     h1 { 
  12.         color: white; 
  13.         text-transform: uppercase; 
  14.         margin-top: 100px; 
  15.         text-align: center; 
  16.         font-size: 6rem; 
  17.         line-height: 1; 
  18.         animation: letterspacing 1s 7 alternate ease-in-out
  19.         display: block; 
  20.         letter-spacing: .5rem; 
  21.     } 
  22.  
  23.     @keyframes letterspacing { 
  24.         0% { 
  25.             letter-spacing: -6rem; 
  26.             filter: blur(1rem); 
  27.         } 
  28.  
  29.         40% { 
  30.             filter: blur(.3rem); 
  31.         } 
  32.  
  33.         80% { 
  34.             letter-spacing: .5rem; 
  35.             filter: blur(0rem); 
  36.         } 
  37.     } 
  38. </style> 
  39. <body> 
  40. <div id="text"
  41.     <h1>歡迎瀏覽</h1> 
  42. </div> 
  43. </body> 
  44. <script> 
  45.     var oH1=document.querySelector('h1'),nowIndex=0; 
  46.     console.log(oH1) 
  47.     var timer = setInterval(function () { 
  48.         nowIndex++; 
  49.         switch (nowIndex) { 
  50.             case 1: 
  51.                 oH1.innerHTML = '守候的文章'
  52.                 break; 
  53.             case 2: 
  54.                 oH1.innerHTML = '愿您瀏覽愉快'
  55.                 break; 
  56.             case 3: 
  57.                 oH1.innerHTML = '學到知識'
  58.                 break; 
  59.         } 
  60.         if (nowIndex > 3) { 
  61.             setTimeout(() => { 
  62.                 clearInterval(timer); 
  63.             }, 2000) 
  64.         } 
  65.     }, 2000) 
  66. </script> 
  67. </html> 

3、導航滑塊

運行效果

原理分析

首先,下面是頁面初始化的時候,橙色滑塊的位置

鼠標放到第二個tab上面,大家可以看到,橙色滑塊就是向右偏移了一個tab的距離

鼠標放到第三個tab上面,大家可以看到,橙色滑塊就是向右偏移了兩個tab的距離

如果從第一個tab到第六個tab的索引是0,1,2,3,4,5。

那么滑塊的公式就是(索引*tab的寬度)。大家看到有逐漸過去的效果,其實是css3過渡(transition)的效果。大家看下面的代碼就行了,一看就懂!代碼如下:

vue方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6. </head> 
  7. <link rel="stylesheet" href="reset.css"
  8. <style> 
  9.     .nav{ 
  10.         margin: 40px; 
  11.         position: relative
  12.     } 
  13. .nav li{ 
  14.     floatleft
  15.     width: 100px; 
  16.     height: 40px; 
  17.     line-height: 40px; 
  18.     color: #fff; 
  19.     text-align: center; 
  20.     background: #09f; 
  21.     cursor: pointer; 
  22.     .nav span{ 
  23.         position: relative
  24.         z-index: 2; 
  25.     } 
  26.     .nav .slider{ 
  27.         position: absolute
  28.         transition: all .5s cubic-bezier(0.4, -0.3, 0.57, 1.38); 
  29.         width: 100px; 
  30.         height: 40px; 
  31.         background: #f90; 
  32.         top: 0; 
  33.         left: 0; 
  34.         z-index: 1; 
  35.     } 
  36. </style> 
  37. <body> 
  38. <div class="nav clear" id="nav" @mouseleave="nowIndex=0"
  39.     <ul> 
  40.         <li @mouseenter.stop="nowIndex=0"><span>Tab One</span></li> 
  41.         <li @mouseenter.stop="nowIndex=1"><span>Tab Two</span></li> 
  42.         <li @mouseenter.stop="nowIndex=2"><span>Tab Three</span></li> 
  43.         <li @mouseenter.stop="nowIndex=3"><span>Tab four</span></li> 
  44.         <li @mouseenter.stop="nowIndex=4"><span>Tab five</span></li> 
  45.         <li @mouseenter.stop="nowIndex=5"><span>Tab six</span></li> 
  46.     </ul> 
  47.     <div class="slider" :style="{'transform':'translate3d('+nowIndex*100+'px,0,0)'}"></div> 
  48. </div> 
  49. </body> 
  50. <script src="vue.min.js"></script> 
  51. <script type="text/javascript"
  52.    new Vue({ 
  53.        el:'#nav'
  54.        data:{ 
  55.            nowIndex:0 
  56.        } 
  57.    }) 
  58. </script> 
  59. </html> 

javascript方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6. </head> 
  7. <link rel="stylesheet" href="reset.css"
  8. <style> 
  9.     .nav{ 
  10.         position: relative
  11.     } 
  12. .nav li{ 
  13.     floatleft
  14.     width: 100px; 
  15.     height: 40px; 
  16.     line-height: 40px; 
  17.     color: #fff; 
  18.     text-align: center; 
  19.     background: #09f; 
  20.     cursor: pointer; 
  21.     .nav span{ 
  22.         position: relative
  23.         z-index: 2; 
  24.     } 
  25.     .nav .slider{ 
  26.         position: absolute
  27.         transition: all .5s cubic-bezier(0.4, -0.3, 0.57, 1.38); 
  28.         width: 100px; 
  29.         height: 40px; 
  30.         background: #f90; 
  31.         top: 0; 
  32.         left: 0; 
  33.         z-index: 1; 
  34.     } 
  35. </style> 
  36. <body> 
  37. <div class="nav clear" id="nav"
  38.     <ul> 
  39.         <li><span>Tab One</span></li> 
  40.         <li><span>Tab Two</span></li> 
  41.         <li><span>Tab Three</span></li> 
  42.         <li><span>Tab four</span></li> 
  43.         <li><span>Tab five</span></li> 
  44.         <li><span>Tab six</span></li> 
  45.     </ul> 
  46.     <div class="slider"></div> 
  47. </div> 
  48. </body> 
  49. <script type="text/javascript"
  50.     var oDiv=document.querySelector("#nav"),oLi=oDiv.querySelectorAll("li"),oSlider=document.querySelector(".slider"); 
  51.     oDiv.addEventListener("mouseleave",function () { 
  52.         oSlider.style.transform='translate3d(0,0,0)'
  53.     }) 
  54.     for(var i=0;i<oLi.length;i++){ 
  55.         oLi[i].index=i; 
  56.         oLi[i].addEventListener("mouseenter",function (e) { 
  57.             oSlider.style.transform='translate3d('+this.index*100+'px,0,0)'
  58.         }) 
  59.     } 
  60. </script> 
  61. </html> 

4、輪播圖

運行效果

原理分析

藍框的是li,黑框的是div

初始化狀態(tài)

處于顯示第二張圖片的時候

看到上面,其實也就是控制ul的偏移量(transform:translate3d)。計算公式和上面的滑塊相似,索引(0|1|2|3)*li的寬度。不同的就是,ul的偏移量是取負數(shù),因為ul是想左偏,上面的滑塊是向右偏!

當?shù)谝粡垐D片的時候,ul偏移量設置(transform: translate3d(0px, 0px, 0px))。

當?shù)诙垐D片的時候,ul偏移量設置(transform: translate3d(-1000px, 0px, 0px))。

當?shù)诙垐D片的時候,ul偏移量設置(transform: translate3d(-2000px, 0px, 0px))。以此類推,偏移量很簡單的就能計算出來!

可能我說的大家有點懵,但是,看下面的代碼,就不會懵了,因為代碼也很簡單!

vue方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6.     <link rel="stylesheet" href="reset.css"
  7.     <style> 
  8.         .slide-img { 
  9.             width: 1000px; 
  10.             height: 500px; 
  11.             overflow: hidden; 
  12.             position: relative
  13.             margin: 20px auto; 
  14.         } 
  15.  
  16.         ul { 
  17.             transition: all .5s ease; 
  18.         } 
  19.  
  20.         li { 
  21.             floatleft
  22.         } 
  23.  
  24.         .slide-arrow div { 
  25.             width: 50px; 
  26.             height: 100px; 
  27.             position: absolute
  28.             margin: auto; 
  29.             top: 0; 
  30.             bottom: 0; 
  31.             background: url("http://i1.bvimg.com/1949/4d860a3067fab23b.jpg"no-repeat; 
  32.         } 
  33.  
  34.         .arrow-right { 
  35.             transform: rotate(180deg); 
  36.             right: 0; 
  37.         } 
  38.  
  39.         .arrow-left { 
  40.             left: 0; 
  41.         } 
  42.         .slide-option
  43.             position: absolute
  44.             bottom: 10px; 
  45.             width: 100%; 
  46.             left: 0; 
  47.             text-align: center; 
  48.         } 
  49.         .slide-option span{ 
  50.             display: inline-block; 
  51.             width: 14px; 
  52.             height: 14px; 
  53.             border-radius: 100%; 
  54.             background: #ccc; 
  55.             margin: 0 10px; 
  56.         } 
  57.         .slide-option .active{ 
  58.             background: #09f; 
  59.         } 
  60.     </style> 
  61. </head> 
  62. <body> 
  63. <div class="slide-img clear" id="slide-img"
  64.     <!--用tran這個class控制ul是否含有過渡效果,樣式已經(jīng)寫好--> 
  65.     <ul :style="{'width':(listWidth*list.length)+'px','transform':'translate3d(-'+(listWidth*nowIndex)+'px,0,0)'}"
  66.         <!--遍歷出來的圖片--> 
  67.         <li v-for="(li,index) in list" :style="{'width':listWidth+'px'}"
  68.             <a href="javascript:;"
  69.                 <img :src="li" class="slider-img"/> 
  70.             </a> 
  71.         </li> 
  72.     </ul> 
  73.     <div class="slide-option"
  74.         <span v-for="(li,index) in list" :class="{'active':index===nowIndex}"></span> 
  75.     </div> 
  76.     <div class="slide-arrow"
  77.         <div class="arrow-left" @click.stop="switchDo('reduce')"></div> 
  78.         <div class="arrow-right" @click.stop="switchDo"></div> 
  79.     </div> 
  80. </div> 
  81. </body> 
  82. <script src="vue.min.js"></script> 
  83. <script type="text/javascript"
  84.     new Vue({ 
  85.         el: '#slide-img'
  86.         data: { 
  87.             nowIndex: 0, 
  88.             listWidth: '1000'
  89.             list: ['./images/timg1.jpg''./images/timg2.jpg''./images/timg3.jpg''./images/timg4.jpg'], 
  90.             timer:null 
  91.         }, 
  92.         methods: { 
  93.             //滑動操作 
  94.             switchDo(reduce){ 
  95.                 clearInterval(this.timer); 
  96.                 //根據(jù)reduce判斷this.nowIndex的增加或者減少! 
  97.                 if(reduce==='reduce'){ 
  98.                     //如果是第一張,就返回最后一張 
  99.                     if(this.nowIndex===0){ 
  100.                         this.nowIndex=this.list.length-1; 
  101.                     } 
  102.                     else
  103.                         this.nowIndex--; 
  104.                     } 
  105.                 } 
  106.                 else
  107.                     //如果是最后一張,就返回第一張 
  108.                     if(this.nowIndex===this.list.length-1){ 
  109.                         this.nowIndex=0; 
  110.                     } 
  111.                     else
  112.                         this.nowIndex++; 
  113.                     } 
  114.                 } 
  115.                 var _this=this; 
  116.                 this.timer=setInterval(function () { 
  117.                     _this.switchDo(); 
  118.                 },4000) 
  119.  
  120.             }, 
  121.         }, 
  122.         mounted(){ 
  123.             var _this=this; 
  124.             this.timer=setInterval(function () { 
  125.                 _this.switchDo(); 
  126.             },4000) 
  127.         } 
  128.     }) 
  129. </script> 
  130. </html> 

javascript方式

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3. <head> 
  4.     <meta charset="UTF-8"
  5.     <title>Title</title> 
  6.     <link rel="stylesheet" href="reset.css"
  7.     <style> 
  8.         .slide-img { 
  9.             width: 1000px; 
  10.             height: 500px; 
  11.             overflow: hidden; 
  12.             position: relative
  13.             margin: 20px auto; 
  14.         } 
  15.  
  16.         ul { 
  17.             transition: all .5s ease; 
  18.         } 
  19.  
  20.         li { 
  21.             floatleft
  22.         } 
  23.  
  24.         .slide-arrow div { 
  25.             width: 50px; 
  26.             height: 100px; 
  27.             position: absolute
  28.             margin: auto; 
  29.             top: 0; 
  30.             bottom: 0; 
  31.             background: url("http://i1.bvimg.com/1949/4d860a3067fab23b.jpg"no-repeat; 
  32.         } 
  33.  
  34.         .arrow-right { 
  35.             transform: rotate(180deg); 
  36.             right: 0; 
  37.         } 
  38.  
  39.         .arrow-left { 
  40.             left: 0; 
  41.         } 
  42.         .slide-option
  43.             position: absolute
  44.             bottom: 10px; 
  45.             width: 100%; 
  46.             left: 0; 
  47.             text-align: center; 
  48.         } 
  49.         .slide-option span{ 
  50.             display: inline-block; 
  51.             width: 14px; 
  52.             height: 14px; 
  53.             border-radius: 100%; 
  54.             background: #ccc; 
  55.             margin: 0 10px; 
  56.         } 
  57.         .slide-option .active{ 
  58.             background: #09f; 
  59.         } 
  60.     </style> 
  61. </head> 
  62. <body> 
  63. <div class="slide-img clear" id="slide-img"
  64.     <!--用tran這個class控制ul是否含有過渡效果,樣式已經(jīng)寫好--> 
  65.     <ul id="slide-img-ul"
  66.         <!--遍歷出來的圖片--> 
  67.         <li style="width: 1000px;"><a href="javascript:;"><img src="images/timg1.jpg" class="slider-img"/></a></li> 
  68.         <li style="width: 1000px;"><a href="javascript:;"><img src="images/timg2.jpg" class="slider-img"/></a></li> 
  69.         <li style="width: 1000px;"><a href="javascript:;"><img src="images/timg3.jpg" class="slider-img"/></a></li> 
  70.         <li style="width: 1000px;"><a href="javascript:;"><img src="images/timg4.jpg" class="slider-img"/></a></li> 
  71.     </ul> 
  72.     <div class="slide-option"
  73.         <span></span> 
  74.         <span></span> 
  75.         <span></span> 
  76.         <span></span> 
  77.     </div> 
  78.     <div class="slide-arrow"
  79.         <div class="arrow-left"></div> 
  80.         <div class="arrow-right"></div> 
  81.     </div> 
  82. </div> 
  83. </body> 
  84. <script type="text/javascript"
  85.     window.onload=function () { 
  86.         var oUl=document.querySelector('#slide-img-ul'); 
  87.         var oLi=oUl.querySelectorAll('li'); 
  88.         var oSpan=document.querySelector('.slide-option').querySelectorAll('span'); 
  89.         var oArrowLeft=document.querySelector('.arrow-left'); 
  90.         var oArrowRight=document.querySelector('.arrow-right'); 
  91.         oUl.style.width='4000px'
  92.         oArrowLeft.addEventListener('click',function () { 
  93.             switchDo('reduce'); 
  94.         }) 
  95.         oArrowRight.addEventListener('click',function () { 
  96.             switchDo(); 
  97.         }) 
  98.         var timer=null,nowIndex=0; 
  99.         function switchDo(reduce){ 
  100.             clearInterval(timer); 
  101.             //設置樣式 
  102.             oUl.style.transform='translate3d(-'+(1000*nowIndex)+'px,0,0)'
  103.             for (var i=0;i<oSpan.length;i++){ 
  104.                 if(i===nowIndex){ 
  105.                     oSpan[i].className='active'
  106.                 } 
  107.                 else
  108.                     oSpan[i].className=''
  109.                 } 
  110.             } 
  111.             //根據(jù)reduce判斷this.nowIndex的增加或者減少! 
  112.             if(reduce==='reduce'){ 
  113.                 //如果是第一張,就返回最后一張 
  114.                 if(nowIndex===0){ 
  115.                     nowIndex=oLi.length-1; 
  116.                 } 
  117.                 else
  118.                     nowIndex--; 
  119.                 } 
  120.             } 
  121.             else
  122.                 //如果是最后一張,就返回第一張 
  123.                 if(nowIndex===oLi.length-1){ 
  124.                     nowIndex=0; 
  125.                 } 
  126.                 else
  127.                     nowIndex++; 
  128.                 } 
  129.             } 
  130.             timer=setInterval(function () { 
  131.                 switchDo(); 
  132.             },4000) 
  133.         } 
  134.         switchDo(); 
  135.     } 
  136. </script> 
  137. </html> 

5、小結

好了,關于vue+css3開發(fā)的特效,以及和javascript+css3的對比,就說到這里了,希望這三個小實例,能幫到大家了解下應該怎么使用vue+css3開發(fā)特效的。今天講這三個小實例不是說給大家代碼,讓大家復制粘貼使用,而是希望能起到一個拋磚引玉的作用,拓展思維的作用!就像我之前寫文章說得那樣,我寫文章是希望能起到一個授人以漁的作用,而不是授人以魚!最后,如果大家覺得有什么地方我寫錯了,寫錯不好,或者有其它什么建議,歡迎指出!讓大家相互學習,共同進步! 

責任編輯:龐桂玉 來源: segmentfault
相關推薦

2019-03-11 15:26:26

HTTPSHTTP密鑰

2019-10-25 09:35:58

HTTPSHTTP通信

2019-11-13 09:08:50

HTTPS安全加密算法

2015-01-19 17:44:02

Cocos引擎3D特效

2013-11-25 17:14:33

Windows 9

2019-11-15 09:26:36

OAuthWeb系統(tǒng)

2012-05-24 11:03:55

HTML5

2013-04-10 09:28:24

CSS3CSS

2011-11-25 13:18:40

HTML 5

2023-12-25 09:41:37

點云訓練

2010-09-14 20:02:14

2012-02-24 09:11:45

jQuery

2013-07-31 14:19:06

Windows 8.1

2017-04-11 13:52:02

華為

2017-04-12 16:27:52

華為

2011-02-17 10:54:59

CSS3變換 簡單快捷

2011-12-16 11:11:36

HTML 5

2021-01-20 14:25:53

Vue3CSS前端

2021-08-23 13:25:25

Vue3CSS前端

2021-12-21 21:58:24

數(shù)字故宮小程序
點贊
收藏

51CTO技術棧公眾號

欧美成人精品一区二区综合免费| 亚洲在线不卡| 亚洲欧美自拍视频| 国产探花在线精品一区二区| 欧美午夜宅男影院| 国产精品无码乱伦| 无码国精品一区二区免费蜜桃| 国产精品一级| 日韩在线播放一区| 91九色蝌蚪porny| 456亚洲精品成人影院| 亚洲欧美激情在线| 久久精品国产综合精品| 中文在线免费看视频| 欧美激情在线| 亚洲人在线观看| aaaaa黄色片| 日本精品裸体写真集在线观看| 亚洲欧美中日韩| 久久精品成人一区二区三区蜜臀 | 国产成人+综合亚洲+天堂| 成人欧美一区二区三区黑人一| 中文字幕日韩高清在线| 欧美在线观看视频一区二区| 岛国大片在线播放| 欧美精品日韩少妇| 久久精品视频在线免费观看 | 97成人在线观看| 亚洲在线播放| 久久免费成人精品视频| 在线观看美女av| 欧美一级精品片在线看| 亚洲精品久久久久久久久久久 | 亚洲国产精选| 色猫猫国产区一区二在线视频| 久久综合亚洲精品| 欧美96在线| 国产精品欧美精品| 日本在线免费观看一区| 亚洲欧美日韩动漫| 成人丝袜视频网| 亚洲综合在线做性| 国产又黄又粗又长| 美女性感视频久久| 国产精品视频999| 懂色av蜜臀av粉嫩av分享吧最新章节| 在线精品观看| 久久人人爽人人| 久久精品这里只有精品| 综合激情一区| 久久香蕉频线观| 日本高清不卡免费| 亚洲精品久久| 久久久精品久久久久| 91精品一区二区三区蜜桃| 久久在线播放| 久久精品国产欧美亚洲人人爽| 精品一区二区6| 欧美韩国日本在线观看| 日韩视频中文字幕| caoporn91| 激情丁香综合| 欧美亚洲午夜视频在线观看| 青青草免费观看视频| 噜噜噜在线观看免费视频日韩 | 黄频视频在线观看| av中文字幕在线观看| 亚洲精品视频一区| 男人c女人视频| 91九色国产在线播放| 亚洲香肠在线观看| www.中文字幕在线| 日韩电影免费观| 欧美日韩一区二区三区视频| 粉色视频免费看| 国产亚洲观看| 日韩av网站电影| 欧美 日韩 国产 成人 在线观看 | 亚洲欧美日韩国产中文| 久久精品—区二区三区舞蹈| 欧洲grand老妇人| 色老头一区二区三区在线观看| 一本一本久久a久久| 欧美一区二区三区久久精品茉莉花| 久久亚洲精品成人| 日韩成人一区二区三区| 视频一区二区三区中文字幕| 国产精品夜间视频香蕉| 性欧美18一19性猛交| 99久久精品情趣| 亚洲高清在线播放| 毛片在线网址| 欧美亚洲自拍偷拍| 成人啪啪18免费游戏链接| 亚洲人和日本人hd| 久久久999成人| 日本道在线观看| 久久精品99国产精品| 99精品99久久久久久宅男| 日本国产在线| 一区二区视频在线| 激情婷婷综合网| 中文字幕区一区二区三| 在线观看91久久久久久| 国产一级一级片| 久久电影网站中文字幕| 狠狠干一区二区| 国产精品扒开做爽爽爽的视频 | 久久精品最新地址| 中文字幕视频网| 国产精品一区二区久久不卡| 欧美日韩一区在线播放| 五月婷婷视频在线观看| 欧美影院午夜播放| 日本黄色免费观看| 欧美激情精品久久久六区热门| 欧美专区中文字幕| www男人的天堂| 国产精品网站导航| www.com毛片| 91精品尤物| 日韩中文字幕网站| 丰满人妻老熟妇伦人精品| 国产美女视频91| 亚洲不卡1区| 国产丝袜在线播放| 日韩精品一区二区三区四区视频 | 精品国产欧美日韩| 91高清在线免费观看| www.黄色片| 欧美国产成人在线| www.国产区| 亚洲婷婷丁香| 欧美在线视频一区二区| 色wwwwww| 亚洲综合一二区| 91亚洲一区二区| 久久久影院免费| 国产精品久久77777| 你懂的免费在线观看视频网站| 亚洲国产精品人人做人人爽| 蜜桃视频无码区在线观看| 羞羞答答成人影院www| 国产女人精品视频| 成人不用播放器| 在线欧美日韩国产| 亚洲精品国产精品国自产网站| 亚洲综合欧美| 久久久综合亚洲91久久98| 黄色在线网站噜噜噜| 亚洲成人精品视频| 五月天婷婷综合网| 91污在线观看| 女性隐私黄www网站视频| 亚洲免费观看高清完整版在线观| 2021久久精品国产99国产精品| 人妻少妇精品无码专区| 午夜精品爽啪视频| av网站有哪些| 可以免费看不卡的av网站| 日韩电影天堂视频一区二区| 免费污视频在线一区| 揄拍成人国产精品视频| 中文字幕在线观看1| 国产精品成人一区二区艾草| 天天干天天色天天干| 在线成人直播| 国产乱码精品一区二区三区中文| 日韩电影免费看| 国产一区二区欧美日韩| 91午夜交换视频| 亚洲最大成人综合| 欧美 日本 国产| 青青草97国产精品免费观看| 亚洲一区免费看| 影音先锋欧美激情| 91高清视频免费| 成年人视频网站在线| 7777精品伊人久久久大香线蕉的 | 国产专区欧美专区| 欧美24videosex性欧美| 国产丝袜视频一区| 亚洲一区二区三区高清视频| 亚洲天堂中文字幕| 人妻在线日韩免费视频| 免费人成精品欧美精品| 99er在线视频| 精品高清在线| 97碰碰视频| 成人午夜精品| 欧美国产第一页| 99reav在线| 精品国产百合女同互慰| 波多野结衣家庭主妇| 亚洲精品国产a| 欧美 日本 国产| 国产一区二区三区在线观看免费 | 日韩视频一区二区三区在线播放| 欧美精品亚洲精品日韩精品| 国产精品久久影院| 久久人妻少妇嫩草av无码专区| 男男成人高潮片免费网站| 免费看欧美黑人毛片| 成人激情视频| 国产日韩欧美一区二区三区四区| 久久精品资源| 5566成人精品视频免费| 成人免费在线| 中文日韩电影网站| 天堂av在线免费观看| 欧美一区二区三区啪啪| 日韩国产成人在线| 亚洲成人av一区二区三区| 成人信息集中地| 国产天堂亚洲国产碰碰| 欧类av怡春院| 国产九九视频一区二区三区| 成人一区二区三| 国产一区二区高清| 福利视频一二区| 羞羞答答成人影院www| 五月天亚洲综合| 五月国产精品| 国产精品久久久久久久小唯西川 | 欧美乱妇23p| 国产第一页在线观看| 亚洲成人自拍偷拍| 欧美色图亚洲天堂| 亚洲色图.com| 欧美乱大交做爰xxxⅹ小说| 久久久久青草大香线综合精品| 天天躁日日躁狠狠躁av麻豆男男 | 国产精品激情电影| 在线观看污视频| 国产精品97| 亚洲一区三区| 91视频综合| 亚洲欧美日韩综合一区| 欧美日韩国产免费观看视频| 蜜桃精品久久久久久久免费影院 | 青青草成人免费| 综合久久国产九一剧情麻豆| 日本精品久久久久中文| 日本一区二区三区在线不卡| 成人午夜福利一区二区| 久久久九九九九| 受虐m奴xxx在线观看| 久久综合久久久久88| a毛片毛片av永久免费| 久久综合九色综合97婷婷| 在线精品一区二区三区| 99久久婷婷国产综合精品电影| 男男做爰猛烈叫床爽爽小说| 成人午夜视频在线| 五月天激情小说| av在线播放成人| 日本xxx在线播放| 久久免费看少妇高潮| 性の欲びの女javhd| 国产精品理论在线观看| 美女的奶胸大爽爽大片| 亚洲一区二区三区四区在线免费观看 | 中文字幕乱码亚洲精品一区| 色综合99久久久无码国产精品| 国产精品嫩草影院com| 日本午夜在线观看| 亚洲二区在线视频| 日产精品久久久| 在线精品国精品国产尤物884a| 欧美性受xxx黑人xyx性爽| 欧美日韩国产一二三| 午夜精品久久久久久久91蜜桃| 亚洲аv电影天堂网| 欧洲亚洲在线| 日韩最新免费不卡| av免费在线视| 日本免费在线精品| 亚洲精品一区av| 国产一区二区三区四区hd| 国产探花在线精品| 欧美xxxx吸乳| 久久天堂成人| 黄色a级三级三级三级| 99在线精品观看| wwwww黄色| 亚洲v中文字幕| 一级特黄aaa大片| 精品国产成人系列| 午夜视频成人| 性欧美xxxx视频在线观看| 欧美va在线| 99国产在线| 精品日产免费二区日产免费二区| 成人在线免费观看网址| 奶水喷射视频一区| 激情图片中文字幕| 久久久久久日产精品| 国产一二三四区| 91高清在线观看| 亚洲精品国产手机| 中文字幕v亚洲ⅴv天堂| 超碰资源在线| 91精品视频观看| 欧美人与拘性视交免费看| a级片一区二区| 免费观看在线综合色| 亚洲图片综合网| 亚洲欧美日韩在线| 探花国产精品一区二区| 亚洲成人中文字幕| 免费人成在线观看播放视频| 国产91成人在在线播放| 深夜激情久久| 色中文字幕在线观看| 丝袜诱惑制服诱惑色一区在线观看| 日韩精品xxx| 国产精品久久久久久户外露出| 五月激情六月丁香| 精品国产成人系列| 午夜伦理在线视频| 国产日韩中文字幕| 菠萝蜜一区二区| 人妻有码中文字幕| 99re8在线精品视频免费播放| 一区二区视频免费看| 欧美日韩电影一区| 1pondo在线播放免费| 国产999精品视频| 亚洲精品进入| 北条麻妃69av| 91在线观看一区二区| 久久精品国产亚洲AV无码男同| 欧美一区二区三区免费| 久cao在线| 成人av色在线观看| 欧美激情777| www.五月天色| 综合色天天鬼久久鬼色| 国产精品自偷自拍| 久久精品99久久久久久久久| 国产亚洲人成a在线v网站| 日韩精品久久一区| 日韩va欧美va亚洲va久久| 三上悠亚影音先锋| 91成人免费在线视频| 国产高清视频在线播放| 国产成人一区二区三区| 欧美另类69xxxxx| 在线免费视频a| 国产精品免费视频一区| 伊人成人在线观看| 色天天综合狠狠色| 亚瑟国产精品| 喜爱夜蒲2在线| 成人午夜激情影院| 日韩成人一区二区三区| 国产视频亚洲视频| 日本精品裸体写真集在线观看| 亚洲欧美国产不卡| 国产一区视频在线看| 青娱乐91视频| 亚洲成人网久久久| 国产精品av一区二区三区 | 福利成人在线观看| 国产日韩在线免费| 亚洲五月综合| 动漫av在线免费观看| 精品国产91久久久久久老师| 日韩a级作爱片一二三区免费观看| 热久久这里只有| 欧美大黑bbbbbbbbb在线| 国产精品久久久久久久99| 亚洲高清免费视频| 久草在线青青草| 成人网在线免费看| 99视频一区| 中国美女黄色一级片| 日韩午夜精品电影| 自拍一区在线观看| 在线免费观看成人网| 成人污污视频在线观看| 波多野结衣人妻| 欧美黄色免费网站| 精品一区在线| 性久久久久久久久久久久久久| 亚洲成av人片在线| 在线看免费av| 国产精品一区视频| 免费一级片91| 国产午夜福利片| 中文字幕精品www乱入免费视频| 一区二区亚洲视频| 日本在线观看免费视频| 亚洲综合精品久久| 三区四区在线视频| 久久免费看av| 国产精品1区2区| 老熟妇一区二区三区啪啪| 色综合久久悠悠| 成人vr资源|