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

「Strve.Js」可以將字符串轉換為視圖的JS庫

開發 前端
好久沒有寫原創了,今天就發一篇關于自己研發的JS庫——Strve.js的文章。終于體驗了一把自己寫JS庫或框架,自己寫文檔,自己寫工具的樂趣。如果想了解一下Strve.js,可以根據文檔上手一下。

前言

好久沒有寫原創了,今天就發一篇關于自己研發的JS庫——Strve.js的文章。

終于體驗了一把自己寫JS庫或框架,自己寫文檔,自己寫工具的樂趣。

如果想了解一下Strve.js,可以根據文檔上手一下。

官方文檔:

https://www.maomin.club/site/strvejs/

NPM:

https://www.npmjs.com/package/strvejs

Github:

https://github.com/maomincoding/strve

Strve.js

一個可以將字符串轉換為視圖的JS庫。

  • 快速地

超快的虛擬 DOM。

  • ?? 空間小

源代碼文件大小僅僅4kb。

  • 靈活地

易于靈活地拆裝不同的代碼塊。

介紹

Strve.js是一個可以將字符串轉換為視圖的JS庫。這里的字符串指的是模板字符串,所以你僅需要在JavaScript中開發視圖。Strve.js 不僅易于上手,還便于靈活拆裝不同的代碼塊。

如果您想上手項目,那么請看下面怎么安裝它吧!

安裝

CDN

如果你使用原生 ES Modules。

  1. <script type="module"
  2.   import { Strve, render, updateView } from 'https://cdn.jsdelivr.net/npm/strvejs/dist/strve.esm.min.js'
  3. </script> 

 

NPM

  1. npm i strvejs 

命令行工具

create-strve是基于strve.js的項目構建工具,您可以使用它更方便靈活地搭建頁面。

全局安裝

  1. npm install create-strve -g 

查看版本

  1. create-strve -v 

初始化項目

 

  1. create-strve init <projectName> 

快速上手

嘗試 Strve.js 最簡單的方法是使用直接引入CDN鏈接。你可以在瀏覽器打開它,跟著例子學習一些基礎用法。

  1. <!DOCTYPE html> 
  2. <html lang="en"
  3.  
  4. <head> 
  5.     <meta charset="UTF-8"
  6.     <meta http-equiv="X-UA-Compatible" content="IE=edge"
  7.     <meta name="viewport" content="width=device-width, initial-scale=1.0"
  8.     <title>Strve.js</title> 
  9. </head> 
  10.  
  11. <body> 
  12.     <div id="app"></div> 
  13.     <script type="module"
  14.         import { Strve, render, updateView } from 'https://cdn.jsdelivr.net/npm/strvejs/dist/strve.esm.min.js'
  15.  
  16.         const state = { 
  17.             arr: ['1''2'], 
  18.         }; 
  19.  
  20.         function App() { 
  21.             return render` 
  22.               <div class='inner'
  23.                   <button id='btn2' onclick=${usePush}>push</button> 
  24.                   <ul> 
  25.                     ${state.arr.map((todo) => render`<li key=${todo}>${todo}</li>`)} 
  26.                   </ul> 
  27.               </div> 
  28.           `; 
  29.         } 
  30.  
  31.         function usePush() { 
  32.             updateView(() => { 
  33.                 state.arr.push('3'); 
  34.             }); 
  35.         } 
  36.  
  37.         Strve('#app', { 
  38.             data: { state }, 
  39.             template: App 
  40.         }); 
  41.     </script> 
  42. </body> 
  43.  
  44. </html> 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

如果你還想深入學習其他關于Strve.js的內容,你可以繼續往下閱讀。

使用

API

Strve.js目前僅僅有三個API。

  • Strve
  • render
  • updateView

是不是很簡單!快來看看這三個API是什么意思?怎么使用它們?

Strve

  • 參數:
    • string
    • object
  • 詳細:

初始化Strve.js。第一個參數傳入需要掛載到HTML頁面的節點選擇器名稱。第二個參數傳入一個對象,第一個屬性data表示的意思是狀態對象,第二個屬性template表示模板函數。

  1. Strve('#app', { 
  2.     data: { state }, 
  3.     template: App 
  4. }); 

render

  • 類型:Function
  • 詳細:

render`` 是一個標簽函數,標簽函數的語法是函數名后面直接帶一個模板字符串,并從模板字符串中的插值表達式中獲取參數。比如說,你可以在模板字符串中直接可以寫HTML標簽。

  1. function App() { 
  2.     return render` 
  3.         <div class='inner'
  4.             <h1>Hello</h1> 
  5.         </div > 
  6.     `; 

updateView

  • 參數:
    • Function
  • 詳細:

它僅僅有一個參數,這個參數是一個函數。函數體中需要執行將改變頁面狀態的值,例如以下示例中的state.msg。

  1. const state = { 
  2.     msg:'1' 
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.         <div class='inner'
  8.             <button onclick=${useChange}>change</button> 
  9.             <p>{state.msg}</p> 
  10.         } 
  11.         </div > 
  12.     `; 
  13.  
  14. function useChange() { 
  15.     updateView(() => { 
  16.         state.msg = '2'
  17.     }); 

插值

Strve.js 使用了基于 JavaScript 的模板字符串語法,允許開發者聲明式地將 DOM 綁定至底層實例的數據。所有 Strve.js 的模板字符串都是合法的 HTML,所以能被遵循規范的瀏覽器和 HTML 解析器解析。

在底層的實現上,Strve.js 將模板字符串編譯成虛擬 DOM 渲染函數,并把 DOM 操作次數減到最少。

在Strve.js中,你可以盡情的使用JavaScript 的模板字符串,感受它獨特的魅力吧!

文本

數據綁定最常見的形式就是使用符號${}的文本插值:

  1. const state = { 
  2.     msg: 'hello' 
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.         <div class='inner'
  8.             <p>${state.msg}</p> 
  9.         </div > 
  10.     `; 

另外你還可以使用更簡便的方法符號{},同樣可以達到預想的效果。

  1. const state = { 
  2.     msg: 'hello' 
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.         <div class='inner'
  8.             <p>{state.msg}</p> 
  9.         </div > 
  10.     `; 

但是,使用這種符號{}需要注意的是,它只適用于標簽內的文本插值。例如如下這種情況,它是不起作用的,不過你可以使用強大的符號${}。

  1. // Bad 
  2. function App() { 
  3.     return render` 
  4.         <div class='inner'
  5.             <input type="text" value={state.msg}/> 
  6.         } 
  7.         </div > 
  8.     `; 
  9.  
  10. // Good 
  11. function App() { 
  12.     return render` 
  13.         <div class='inner'
  14.             <input type="text" value=${state.msg}/> 
  15.         } 
  16.         </div > 
  17.     `; 

表達式

目前僅支持在符號${}中使用表達式。例如,

  1. const state = { 
  2.     a: 1, 
  3.     b: 2 
  4. }; 
  5.  
  6. function App() { 
  7.     return render` 
  8.         <div class='inner'
  9.             <p>${String(state.a + state.b)}</p> 
  10.         } 
  11.         </div > 
  12.     `; 

屬性綁定

前面,我們可以看到使用符號${}可以與屬性value綁定值。

  1. function App() { 
  2.     return render` 
  3.         <div class='inner'
  4.             <input type="text" value=${state.msg}/> 
  5.         } 
  6.         </div > 
  7.     `; 

另外,你還可以綁定其他屬性,例如class。

  1. const state = { 
  2.     isRed: true 
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.     <div class='inner'
  8.         <p class=${state.isRed ? 'red' : ''}>Strve.js</p> 
  9.     </div > 
  10. `; 

條件渲染

我們也可以使用符號${},這塊內容只會在指令的表達式返回 true 值的時候被渲染。

  1. const state = { 
  2.     isShow: false 
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.         <div class='inner'
  8.             <button onclick=${useShow}>show</button> 
  9.             ${state.isShow ? render`<p>Strve.js</p>` : '' 
  10.         } 
  11.         </div > 
  12.     `; 
  13.  
  14. function useShow() { 
  15.     updateView(() => { 
  16.         state.isShow = !state.isShow; 
  17.     }); 

列表渲染

我們可以用符號${}基于一個數組來渲染一個列表。比如我們使用數組的map方法來渲染列表,并且可以動態添加數組項。

  1. const state = { 
  2.     arr: ['1''2'
  3. }; 
  4.  
  5. function App() { 
  6.     return render` 
  7.         <div class='inner'
  8.             <button onclick=${usePush}>push</button> 
  9.             <ul> 
  10.             ${state.arr.map((todo) => render`<li key=${todo}>${todo}</li>`)} 
  11.             </ul> 
  12.         } 
  13.         </div > 
  14.     `; 
  15.  
  16. function usePush() { 
  17.     updateView(() => { 
  18.         state.arr.push('3'); 
  19.     }); 

事件處理

我們可以使用原生onclick指令來監聽 DOM 事件,并在觸發事件時執行一些 JavaScript。需要使用符號${}來綁定事件。

  1. function App() { 
  2.     return render` 
  3.         <div class='inner'
  4.             <button onclick=${useClick}>sayHello</button> 
  5.         } 
  6.         </div > 
  7.     `; 
  8.  
  9. function useClick() { 
  10.     console.log('hello'); 

與Vue.js搭配

Strve.js不僅可以單獨使用,也可以與Vue.js搭配使用。你需要在Vue實例掛載完成后被調用Strve()注冊方法,并且第一個參數已經在template標簽中存在。

App.vue

  1. <template> 
  2.   <div id="container"
  3.     <HelloWorld/> 
  4.   </div> 
  5. </template> 
  6.  
  7. <script> 
  8. import HelloWorld ,{hello} from './components/HelloWorld.vue'
  9. import { about,state } from './components/About.vue'
  10. import { render, Strve } from "strvejs"
  11. const AppTm = () => render` 
  12.       <div> 
  13.         ${hello()} 
  14.         ${about()} 
  15.       </div> 
  16. `; 
  17. export default { 
  18.   name"App"
  19.   components:{ 
  20.     HelloWorld 
  21.   }, 
  22.   mounted() { 
  23.     Strve("#container", { 
  24.       data: {state}, 
  25.       template: AppTm, 
  26.     }); 
  27.   }, 
  28. }; 
  29. </script> 

如果需要與Vue共享一個方法,推薦在setup方法中使用。

HelloWorld.vue

  1. <template> 
  2.   <div> 
  3.     <img src="../assets/logo.png" alt="" @click="useCliimg"
  4.   </div> 
  5. </template> 
  6. <script> 
  7. import { render } from "strvejs"
  8. import styles from '../assets/hello/hello.module.css'
  9.  
  10. export const hello = ()=>render` 
  11. <h2 class="${styles.color}" onclick=${useCliimg}>hello</h2> 
  12. function useCliimg(){ 
  13.     console.log(1); 
  14.  
  15. export default { 
  16.   name:'HelloWorld'
  17.   setup(){ 
  18.     return { 
  19.       useCliimg 
  20.     } 
  21.   } 
  22. </script> 

如果,你想在Vue組件中完全使用Strve.js,當然也可以。不過最后,推薦使用export default導出組件名。

About.vue

  1. <script> 
  2. import { render, updateView } from "strvejs"
  3. import styles from '../assets/about/about.module.css'
  4.  
  5. export const about = ()=>render` 
  6. <div> 
  7.     <p>{state.msg}</p> 
  8.    <h2 class="${styles.color}" onclick=${useClick}>about</h2> 
  9. </div> 
  10. export const state = { 
  11.     msg:"hello" 
  12.  
  13. function useClick() { 
  14.     updateView(()=>{ 
  15.         state.msg = 'world'
  16.     }) 
  17. export default { 
  18.     name:"About" 
  19. </script> 

與React.js搭配

Strve.js與Vue.js搭配相比,與React.js搭配使用更為靈活。同樣需要在組件第一次渲染完成后調用Strve()方法注冊方法。

App.js

  1. import {useEffect} from 'react' 
  2. import {Strve,render,updateView} from 'strvejs'
  3. import './App.css'
  4.  
  5. const state = { 
  6.   msg:"Hello" 
  7.  
  8. function Home(){ 
  9.   return render`<h1 onclick=${useClick}>{state.msg}</h1>` 
  10.  
  11. function useClick(){ 
  12.   updateView(()=>{ 
  13.     state.msg = "World"
  14.   }) 
  15.  
  16. function App() { 
  17.   useEffect(()=>{ 
  18.     Strve(".App",{ 
  19.       data:{state}, 
  20.       template: Home 
  21.     }) 
  22.   }) 
  23.   return (<div className="App"></div>); 
  24.  
  25. export default App; 

工具

create-strve

在前面我們也簡單介紹過,create-strve是基于Strve.js的項目構建工具,您可以使用它更方便靈活地搭建頁面。create-strve是用Vite來構建的,它是一種新型前端構建工具,能夠顯著提升前端開發體驗。

安裝

全局安裝

  1. npm install create-strve -g 

查看版本

  1. create-strve -v 

初始化項目

  1. create-strve init <projectName> 

啟動

  1. yarn dev 
  2. OR 
  3. npm run dev 

部署

  1. yarn build 
  2.  
  3. OR 
  4.  
  5. npm run build 

配置

因為create-strve是用Vite來構建的,所以你可以按照Vite的約定配置進行自定義配置create-strve。

其它

關于作者

英文名:Vam

昵稱ID:maomincoding

Github:https://github.com/maomincoding

Twitter:https://twitter.com/maomincoding

本文轉載自微信公眾號「前端歷劫之路」,可以通過以下二維碼關注。轉載本文請聯系前端歷劫之路公眾號。

 

責任編輯:武曉燕 來源: 前端歷劫之路
相關推薦

2021-12-23 06:07:21

前端技術編程

2022-02-21 06:02:49

Strve.jsCodepenReact

2024-01-04 09:17:03

前端開發CSV 格式JSON 字符串

2023-07-22 06:55:00

JS框架Strve

2022-11-14 00:14:49

2021-08-12 00:03:37

JSStrview視圖

2024-02-19 15:38:08

JsonPython字符串

2023-06-15 06:57:06

Strve.jsVite

2024-10-08 09:32:08

算法題字符串函數

2022-02-23 10:48:52

TodoList應用項目Strve開發

2009-06-05 11:16:58

字符串動態轉換

2021-12-29 16:40:54

Python語言字符串

2021-09-05 17:22:08

Strview.js工具js

2009-11-25 16:55:45

PHP函數explod

2022-10-12 08:00:00

語音識別Node.js音頻質量

2024-03-12 07:35:39

Python字符串列表

2010-03-31 19:15:25

Oracle函數

2016-12-30 13:16:51

字符串算法代碼

2010-11-26 14:09:32

MySQL內置函數

2009-12-01 14:00:37

PHP字符串轉換為數值
點贊
收藏

51CTO技術棧公眾號

国产精品一区hongkong| 精品国产无码AV| 青青草原综合久久大伊人精品 | 亚洲欧美中文在线视频| 超碰影院在线观看| 性欧美videos高清hd4k| 久久亚洲精精品中文字幕早川悠里| 国产精品露脸av在线| 国产真人真事毛片| 91视频综合| 精品视频在线播放| 中文字幕av一区二区三区人妻少妇| 麻豆av在线免费观看| 国产欧美一区二区三区在线看蜜臀| 成人免费看吃奶视频网站| 国产成人无码精品亚洲| 天天综合网91| 亚洲女人被黑人巨大进入al| 无码人妻少妇色欲av一区二区| 成人软件在线观看| 欧美电影三区| 精品中文字幕久久久久久| 日韩av加勒比| 久久久久久久性潮| 国产精品毛片高清在线完整版| 国产精品日韩一区二区| 国产精品视频第一页| 日韩精品一区二区三区免费观看| 精品国产免费一区二区三区四区| 久热精品在线播放| 欧美韩国亚洲| 黑人精品xxx一区一二区| 日本中文字幕一级片| 浪潮av一区| 欧美国产精品劲爆| 日韩伦理一区二区三区av在线| 免费看黄色一级视频| 亚洲精选久久| 国产视频久久久久久久| 免费啪视频在线观看| 国产高清精品二区| 欧美日韩在线播放三区| 久久综合久久色| 欧美性xxx| 日韩欧美国产视频| 777米奇影视第四色| 免费毛片b在线观看| 亚洲国产综合91精品麻豆| 50度灰在线观看| 午夜成年人在线免费视频| 亚洲女女做受ⅹxx高潮| 成人av资源网| 99视频国产精品免费观看a| 久久99精品国产麻豆不卡| 国产成人鲁鲁免费视频a| 91久久国产综合久久91| 老司机免费视频久久| 日韩av成人在线| 亚洲高清视频免费观看| 日韩在线观看一区二区| 国产精品久久久久不卡| 国产一二三区精品| 亚洲欧美综合久久久| 久久国产精品网站| 久久久无码一区二区三区| 尤物精品在线| 欧美专区在线播放| 国产乡下妇女三片| 国产自产2019最新不卡| 国产精品日韩一区二区三区| 午夜在线观看视频18| 久久久精品国产免费观看同学| 日韩高清在线播放| 97影院秋霞午夜在线观看| 亚洲影院久久精品| 国产精品-区区久久久狼| 福利精品在线| 精品国产一区二区三区av性色| 国产精品一区二区人妻喷水| 国产日韩欧美一区二区三区| 深夜精品寂寞黄网站在线观看| 91日韩中文字幕| 国产日本精品| 国产精品色婷婷视频| 性一交一乱一透一a级| 97久久超碰精品国产| 水蜜桃亚洲精品| 欧美aaaaaaa| 国产污视频网站| 精品一二三四在线| 国产欧美日韩一区二区三区| 九色在线观看| 一区二区三区在线视频播放| aa免费在线观看| 99re8精品视频在线观看| 亚洲激情免费观看| 极品色av影院| 欧美中文日韩| 九九九热精品免费视频观看网站| 日韩精品国产一区二区| 久久97超碰色| 日本一区二区三区精品视频| 肉丝一区二区| 日韩美女久久久| 虎白女粉嫩尤物福利视频| 国产精品美女久久久久人| 日韩精品中文字幕在线| 一区二区三区四区五区| 久久精品日产第一区二区| 97se亚洲综合| 在线免费av电影| 欧美色xxxx| 性猛交╳xxx乱大交| 日韩三级在线| 国产精品r级在线| 肥臀熟女一区二区三区| 日韩一区欧美小说| 日日噜噜噜噜久久久精品毛片| 麻豆成人入口| 日韩av网站电影| 精品人妻伦九区久久aaa片| 日韩电影在线免费看| 国产一区免费观看| 蜜臀av在线播放| 欧美一区日本一区韩国一区| 91欧美一区二区三区| 精品视频99| 国产成人av在线| 天堂av网在线| 天天色天天操综合| 玖玖爱在线精品视频| 欧美日韩精品| 欧美在线播放视频| 日本韩国免费观看| 亚洲午夜免费视频| 国产高潮失禁喷水爽到抽搐 | 99视频有精品高清视频| 一区二区三区无码高清视频| 免费看的黄色录像| 老司机久久99久久精品播放免费| 欧美二区三区| 中文字幕这里只有精品| 亚洲精品视频在线播放| 二区视频在线观看| 久久综合狠狠综合久久激情| 久久9精品区-无套内射无码| 电影一区电影二区| 五月婷婷色综合| 欧美熟妇精品一区二区蜜桃视频| 欧美日一区二区在线观看| 97netav| 国产高清在线a视频大全| 欧美精品一区二区三区在线| 国产性xxxx高清| 91色视频在线| 国产免费视频传媒| 日韩精品欧美激情一区二区| 亚洲一区中文字幕在线观看| 午夜小视频在线观看| 亚洲黄页视频免费观看| www.国产一区二区| 国产精品欧美一区喷水| 天天久久综合网| 欧美深夜福利| 欧美国产二区| 亚洲综合资源| 欧美日韩成人网| 色视频在线看| 欧美日韩视频在线第一区| 99视频只有精品| av在线不卡免费看| 中文字幕第21页| 欧美一区成人| 久久久久久99| 羞羞视频在线观看一区二区| 欧美一级生活片| 久久精品免费在线| 国产午夜精品美女毛片视频| 99国产精品久久久久久| 免费成人网www| 成人a在线视频| 成人免费高清观看| 国产亚洲精品久久久久动| 国产精品国产一区二区三区四区| 亚洲一区二区三区四区的| 久久久久久久久久久国产精品| 欧美日韩免费观看一区=区三区| 国产一区二区在线观看免费播放| 成人软件在线观看| 欧美激情成人在线视频| 国产精品自偷自拍| 午夜久久福利影院| 成人一级黄色大片| 91蝌蚪porny| 午夜xxxxx| 性色一区二区三区| 中文字幕在线中文| av中文一区| 国产精品污www一区二区三区| jizz亚洲女人高潮大叫| 91国产视频在线播放| 日本激情在线观看| 亚洲精品之草原avav久久| 国产人妻精品一区二区三| 在线精品亚洲一区二区不卡| 日本免费在线播放| 亚洲特级片在线| 久久久精品成人| 91论坛在线播放| 中文字幕一二三区| 麻豆精品在线看| 老司机午夜av| 亚洲女同同性videoxma| 欧美中文字幕在线观看视频| 欧美a级片视频| 日韩欧美亚洲在线| 神马午夜久久| 国产日本一区二区三区| 久久69av| 成人国产在线激情| 成人国产网站| 国产精品久久久久久久久久东京| 这里有精品可以观看| 午夜精品一区二区三区视频免费看| a级毛片免费观看在线| 日韩在线视频观看| 一区二区高清不卡| 中文字幕免费精品一区高清| 欧洲亚洲精品视频| 亚洲欧美成人网| 涩涩视频在线观看免费| 日韩精品视频在线播放| 日本免费一区视频| 亚洲成人精品视频| 亚洲精品一区二区三区蜜桃| 日韩欧美在线一区二区三区| 国产婷婷在线视频| 日韩一区二区三区视频在线观看 | 午夜亚洲一区| 欧美日韩黄色一级片| 99国产精品| 五月婷婷综合色| 国产99久久久国产精品成人免费| 蜜桃av久久久亚洲精品| 校花撩起jk露出白色内裤国产精品| 国产美女精品久久久| 久久综合五月婷婷| 欧美男人的天堂| 国产99精品| 亚洲精品日韩精品| 久久久久av| 精品人妻人人做人人爽| 国内精品久久久久久久97牛牛 | 日本少妇高清视频| 夜夜爽夜夜爽精品视频| 麻豆一区二区三区精品视频| 婷婷成人激情在线网| 无码人妻精品一区二区| 欧美日韩中文另类| av综合在线观看| 亚洲黄在线观看| 国产区在线视频| 久久精品国产精品亚洲| 精品日韩av| 日本sm极度另类视频| 免费一级欧美在线观看视频| 97超级碰碰| 偷窥自拍亚洲色图精选| 日韩影视精品| 欧美激情日韩| 亚洲色欲综合一区二区三区| 欧美aaaaa成人免费观看视频| 伊人成人免费视频| 波多野洁衣一区| 欧美日韩生活片| 一区二区三区四区五区视频在线观看| 日本一区二区欧美| 欧美视频中文字幕| 亚洲精品字幕在线| 国产亚洲xxx| 亚洲区欧洲区| 国产精品爱久久久久久久| 精品国产一区二区三区性色av| 精品国产乱码久久久久久丨区2区| jlzzjlzz亚洲女人| www.av毛片| 麻豆国产一区二区| 在线黄色免费网站| 综合亚洲深深色噜噜狠狠网站| 国产手机在线视频| 在线成人av网站| 亚洲高清在线看| 日韩欧美自拍偷拍| 成人精品一区二区三区校园激情| 精品中文字幕在线观看| 欧美精品资源| 精品视频在线观看| 综合亚洲视频| 亚洲天堂2018av| 91麻豆免费看片| 欧美精品色哟哟| 欧美色图12p| 嫩草研究院在线| 午夜精品久久久久久久久久久久久 | 日韩一区二区免费电影| 国产精品麻豆一区二区三区 | 免费的一级黄色片| 蜜臀久久99精品久久久久宅男 | 手机看片福利在线| 亚洲国产精品网站| 影音先锋在线播放| 国产日韩欧美视频在线| 九一精品国产| 亚洲人精品午夜射精日韩| 国产精品一品二品| 男人在线观看视频| 欧美日韩中字一区| 97电影在线| 国产精品99久久99久久久二8| 国产精品jk白丝蜜臀av小说| 97超碰人人爱| 精品一二三四区| 永久免费看mv网站入口| 欧美日本国产视频| lutube成人福利在线观看| 欧美尤物巨大精品爽| 欧美有码在线| 一女被多男玩喷潮视频| 成人黄色在线看| 国产午夜福利片| 精品国产99国产精品| 欧美高清另类hdvideosexjaⅴ| 91久久在线播放| 91成人观看| 波多野结衣在线免费观看| 亚洲欧美韩国综合色| 国产欧美日韩成人| 欧美巨大黑人极品精男| 久久久久久亚洲精品美女| 神马午夜伦理影院| 国产伦精品一区二区三区免费迷| 欧美 日韩 国产 一区二区三区| 欧美高清一级片在线| 超碰在线免费播放| 99久久精品免费看国产一区二区三区| 在线成人激情| 中文字幕欧美视频| 亚洲制服丝袜在线| 手机av免费在线观看| 国产成人精品视频在线| 欧美亚洲在线日韩| 国产亚洲视频一区| 亚洲永久精品大片| 香蕉av一区二区三区| 国产999精品视频| 欧美大人香蕉在线| 日本女人黄色片| 婷婷综合在线观看| 狠狠狠综合7777久夜色撩人| 国产精品美女视频网站| 天天综合网网欲色| 韩国三级hd两男一女| 日韩欧美国产中文字幕| 中文字幕日本在线观看| 99久久久久国产精品免费| 亚洲韩日在线| 国产一区二区三区精品在线| 宅男在线国产精品| 91美女精品| 日韩欧美亚洲在线| 懂色av中文字幕一区二区三区| 午夜毛片在线观看| 日韩欧美第一区| 在线看的毛片| 综合久久国产| 99久久伊人久久99| 中文字幕1区2区3区| 欧美人与性动交| 国产一区二区电影在线观看| 波多野结衣免费观看| 色综合久久中文综合久久牛| 精品视频在线一区二区| 久久久久久久免费| 久久精品国产精品亚洲红杏 | 欧美欧美午夜aⅴ在线观看| 色呦呦在线视频| 日韩欧美在线一区二区| 国产91丝袜在线观看| 中国a一片一级一片| 欧美激情极品视频| 日韩毛片视频| 久久久久成人精品无码中文字幕| 欧美日韩激情一区二区| a天堂资源在线| 最新精品视频| 久久久久久久久岛国免费| www.久久久久久| 国产日韩精品电影| 午夜在线a亚洲v天堂网2018| 青娱乐国产精品|