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

從零開發(fā)一個node命令行工具

開發(fā) 前端
本文列舉的只是 cli 開發(fā)的冰山一角,想要開發(fā)出強(qiáng)大的 cli 工具,除了需要熟悉 node 和常用工具包,更重要的是了解 linux 常用命令和文件系統(tǒng)。

[[267652]]

什么是命令行工具?

命令行工具(Cmmand Line Interface)簡稱cli,顧名思義就是在命令行終端中使用的工具。我們常用的 git 、npm、vim 等都是 cli 工具,比如我們可以通過 git clone 等命令簡單把遠(yuǎn)程代碼復(fù)制到本地。

為什么要用cli工具?

和 cli 相對的是圖形用戶界面(gui),windows 環(huán)境中幾乎都是 gui 工具,而 linux 環(huán)境中則幾乎都是 cli 工具,因為兩者用戶不同,gui 側(cè)重于易用,cli 則側(cè)重于效率。對于熟悉 gui 和集成開發(fā)環(huán)境(IDE)的程序員,這似乎很難理解。畢竟用鼠標(biāo)點(diǎn)點(diǎn)拽拽,不是更方便么?

很遺憾,答案是否定的。gui對于某些簡單操作,可能更快、更方便。比如移動文件、閱讀郵件或?qū)憌ord文檔。但如果你依賴 gui 完成全部工作,你將會錯過環(huán)境的某些能力,比如使常見任務(wù)自動化,或是利用各種工具的全部功能。并且,你也無法將工具組合,創(chuàng)建出定制的宏工具。gui 的好處是所見即所得(what you see is what you get)。缺點(diǎn)是所見即全部所得(what you see is all you get)。

作為注重實效的程序員,你不斷的想要執(zhí)行特別的操作(gui 可能不支持的操作)。當(dāng)你想要快速地組合一些命令,以完成一次查詢或某種其他的任務(wù)時,cli 要更為合適。比如:查看上周哪些js文件沒有改動過: 

  1. # cli:  
  2. find . -name '*.js' -mtime +7 -print  
  3. # gui:  
  4. 1.點(diǎn)擊并轉(zhuǎn)到"查找文件",點(diǎn)擊"文件名"字段,敲入"*.js",選擇"修改日期"選項卡;  
  5. 2.然后選擇"介于".點(diǎn)擊"開始日期",敲入項目開始的日期。  
  6. 3.點(diǎn)擊"結(jié)束日期",敲入1周以前的日期(確保手邊有日歷),點(diǎn)擊"開始查找"; 

如何開發(fā)一個 cli 工具?

基本上,使用任何成熟的語言都可以開發(fā) cli 工具,作為一個前端小白,還是 JavaScript 比較順手,因此我們選用 node 作為開發(fā)語言。

創(chuàng)建一個項目 

  1. # 1.創(chuàng)建一個目錄:  
  2. mkdir kid-cli && cd kid-cli  
  3. # 2.因為最終我們要把cli發(fā)布到npm上,所以需要初始化一個程序包:   
  4. npm init  
  5. # 3.創(chuàng)建一個index.js文件  
  6. touch index.js  
  7. # 4.打開編輯器(vscode)  
  8. code  . 

安裝 code 命令,運(yùn)行 VS code 并打開命令面板( ⇧⌘P ),然后輸入 shell command 找到: Install 'code' command in PATH 就行了。

打開index.js文件,添加一段測試代碼: 

  1. #!/usr/bin/env node  
  2. console.log('hello world!’) 

終端運(yùn)行 node 程序,需要先輸入 node 命令,比如 

  1. node index.js 

可以正確輸出 hello world!,代碼頂部的 #!/usr/bin/env node是告訴終端,這個文件要使用 node 去執(zhí)行。

創(chuàng)建一個命令

一般 cli都有一個特定的命令,比如 git,剛才使用的 code 等,我們也需要設(shè)置一個命令,就叫 kid 吧!如何讓終端識別這個命令呢?很簡單,打開 package.json 文件,添加一個字段 bin,并且聲明一個命令關(guān)鍵字和對應(yīng)執(zhí)行的文件: 

  1. # package.json  
  2. ......  
  3.   "bin": {  
  4.     "kid": "index.js"  
  5.   },  
  6. ...... 

如果想聲明多個命令,修改這個字段就好了。

然后我們測試一下,在終端中輸入 kid,會提示: 

  1. zsh: command not found: kid 

為什么會這樣呢?回想一下,通常我們在使用一個 cli 工具時,都需要先安裝它,比如 vue-cli,使用前需要全局安裝: 

  1. npm i vue-cli -g 

而我們的 kid-cli 并沒有發(fā)布到 npm 上,當(dāng)然也沒有安裝過了,所以終端現(xiàn)在還不認(rèn)識這個命令。通常我們想本地測試一個 npm 包,可以使用:npm link 這個命令,本地安裝這個包,我們執(zhí)行一下: 

  1. npm link 

然后再執(zhí)行 

  1. kid 

命令,看正確輸出 hello world! 了。

到此,一個簡單的命令行工具就完成了,但是這個工具并沒有任何卵用,別著急,我們來一點(diǎn)一點(diǎn)增強(qiáng)它的功能。

查看版本信息

首先是查看 cli 的版本信息,希望通過如下命令來查看版本信息: 

  1. kid -v 

這里有兩個問題

  1.  如何獲取 -v 這參數(shù)?
  2.  如何獲取版本信息?

在 node 程序中,通過 process.argv 可獲取到命令的參數(shù),以數(shù)組返回,修改 index.js,輸出這個數(shù)組: 

  1. console.log(process.argv) 

然后輸入任意命令,比如: 

  1. kid -v -h -lalala 

控制臺會輸出 

  1. [ '/Users/shaolong/.nvm/versions/node/v8.9.0/bin/node',  
  2.   '/Users/shaolong/.nvm/versions/node/v8.9.0/bin/kid',  
  3.   '-v',  
  4.   '-h',  
  5.   '-lalala' ] 

這個數(shù)組的第三個參數(shù)就是我們想要的 -v。

第二個問題,版本信息一般是放在package.json 文件的 version 字段中, require 進(jìn)來就好了,改造后的 index.js 代碼如下: 

  1. #!/usr/bin/env node  
  2. const pkg = require('./package.json')  
  3. const command = process.argv[2]  
  4. switch (command) {  
  5.     case '-v':  
  6.     console.log(pkg.version)  
  7.     break  
  8.     default:  
  9.     break  

然后我們再執(zhí)行kid -v,就可以輸出版本號了。

初始化一個項目

接下來我們來實現(xiàn)一個最常見的功能,利用 cli 初始化一個項目。

整個流程大概是這樣的:

  1.  cd 到一個你想新建項目的目錄;
  2.  執(zhí)行 kid init 命令,根據(jù)提示輸入項目名稱;
  3.  cli 通過 git 拉取模版項目代碼,并拷貝到項目名稱所在目錄中;

為了實現(xiàn)這個流程,我們需要解決下面幾個問題:

執(zhí)行復(fù)雜的命令

上面的例子中,我們通過 process.argv 獲取到了命令的參數(shù),但是當(dāng)一個命令有多個參數(shù),或者像新建項目這種需要用戶輸入項目名稱(我們稱作“問答”)的命令時,一個簡單的swith case 就顯得捉襟見肘了。這里我們引用一個專門處理命令行交互的包:commander。 

  1. npm i commander --save 

然后改造index.js 

  1. #!/usr/bin/env node  
  2. const program = require('commander')  
  3. program.version(require('./package.json').version)  
  4. program.parse(process.argv) 

運(yùn)行 

  1. kid -h 

會輸出 

  1. Usage: kid [options] [command]  
  2. Options:  
  3.   -V, --version  output the version number  
  4.   -h, --help     output usage information 

commander已經(jīng)為我們創(chuàng)建好了幫助信息,以及兩個參數(shù) -V 和 -h,上面代碼中的program.version 就是返回版本號,和之前的功能一致,program.parse 是將命令參數(shù)傳入commander 管道中,一般放在***執(zhí)行。

添加問答操作

接下來我們添加 kid init 的問答操作,這里有需要引入一個新的包:inquirer, 這個包可以通過簡單配置讓 cli 支持問答交互。 

  1. npm i inquirer --save 

index.js: 

  1. #!/usr/bin/env node  
  2. const program = require('commander')  
  3. var inquirer = require('inquirer')  
  4. const initAction = () => {  
  5.     inquirer.prompt([{  
  6.         type: 'input',  
  7.         message: '請輸入項目名稱:',  
  8.         name: 'name'  
  9.     }]).then(answers => {  
  10.         console.log('項目名為:', answers.name)  
  11.         console.log('正在拷貝項目,請稍等')  
  12.     })  
  13.  
  14. program.version(require('./package.json').version) 
  15. program  
  16.     .command('init')  
  17.     .description('創(chuàng)建項目')  
  18.     .action(initAction)  
  19. program.parse(process.argv) 

program.command 可以定義一個命令,description 添加一個描述,在 --help 中展示,action 指定一個回調(diào)函數(shù)執(zhí)行命令。inquirer.prompt 可以接收一組問答對象,type字段表示問答類型,name 指定答案的key,可以在 answers 里通過 name 拿到用戶的輸入,問答的類型有很多種,這里我們使用 input,讓用戶輸入項目名稱。

運(yùn)行 kid init,然后會提示輸入項目名稱,輸入后會打印出來。

運(yùn)行 shell 腳本

熟悉 git 和 linux 的同學(xué)幾句話便可以初始化一個項目: 

  1. git clone xxxxx.git --depth=1  
  2. mv xxxxx my-project  
  3. rm -rf ./my-project/.git  
  4. cd my-project  
  5. npm i 

那么如何在 node 中執(zhí)行 shell 腳本呢?只需要安裝 shelljs 這個包就可以輕松搞定。 

  1. npm i shelljs --save 

假定我們想克隆 github 上 vue-admin-template 這個項目的代碼,并自動安裝依賴,改造index.js,在 initAction 函數(shù)中加上執(zhí)行shell腳本的邏輯: 

  1. #!/usr/bin/env node  
  2. const program = require('commander')  
  3. const inquirer = require('inquirer')  
  4. const shell = require('shelljs')  
  5. const initAction = () => {  
  6.     inquirer.prompt([{  
  7.         type: 'input',  
  8.         message: '請輸入項目名稱:',  
  9.         name: 'name'  
  10.     }]).then(answers => {  
  11.         console.log('項目名為:', answers.name)  
  12.         console.log('正在拷貝項目,請稍等')        
  13.         const remote = 'https://github.com/PanJiaChen/vue-admin-template.git'  
  14.         const curName = 'vue-admin-template'  
  15.         const tarName = answers.name  
  16.         shell.exec(`  
  17.                 git clone ${remote} --depth=1  
  18.                 mv ${curName} ${tarName}  
  19.                 rm -rf ./${tarName}/.git  
  20.                 cd ${tarName}  
  21.                 npm i  
  22.               `, (error, stdout, stderr) => {  
  23.             if (error) {  
  24.                 console.error(`exec error: ${error}`)  
  25.                 return  
  26.             }  
  27.             console.log(`${stdout}`)  
  28.             console.log(`${stderr}`)  
  29.         });  
  30.     })  
  31.  
  32. program.version(require('./package.json').version)  
  33. program  
  34.     .command('init')  
  35.     .description('創(chuàng)建項目')  
  36.     .action(initAction)  
  37. program.parse(process.argv) 

shell.exec 可以幫助我們執(zhí)行一段腳本,在回調(diào)函數(shù)中可以輸出腳本執(zhí)行的結(jié)果。

測試一下我們初始化功能: 

  1. cd ..  
  2. kid init  
  3. # 輸入一個項目名稱 

可以看到,cli已經(jīng)自動從github上拉取vue-admin-template的代碼,放在指定目錄,并幫我們自動安裝了依賴。

尾聲

***別忘了將你的 cli 工具發(fā)布到 npm 上,給更多的同學(xué)使用。 

  1. npm publish 

怎么樣,是不是感覺看似神秘的命令行開發(fā)其實也沒有什么技術(shù)含量,上文列舉的只是 cli 開發(fā)的冰山一角,想要開發(fā)出強(qiáng)大的 cli 工具,除了需要熟悉 node 和常用工具包,更重要的是了解 linux 常用命令和文件系統(tǒng),希望各位同學(xué)可以受到啟發(fā),開發(fā)出屬于自己的 cli 工具。

安利時間

前端的技術(shù)點(diǎn)眾多,其中不乏抽象且晦澀的知識點(diǎn),它們用文字無法很直觀的表述出來,所以眾多開發(fā)者對這些知識點(diǎn)的理解都是是而非,如果我們通過圖畫來展示,就會很容易理解。因此Diagram項目希望開發(fā)者能通過這種方式吃透前端技術(shù)領(lǐng)域的知識點(diǎn)。 

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

2021-02-02 10:15:55

工具命令行Node

2019-05-30 10:40:04

ddgrLinuxDuckDuckGo

2011-06-17 16:49:05

Cocoa蘋果

2016-08-10 12:41:00

Linux工具bcShell

2020-12-11 06:44:16

命令行工具開發(fā)

2020-12-10 16:16:08

工具代碼開發(fā)

2020-12-08 08:46:07

GoJava工具

2025-08-06 01:45:00

2021-04-01 13:25:46

Node命令工具

2022-02-17 18:21:47

工具HTTPie客戶端

2018-05-04 09:15:35

PythonPlumbum命令行

2016-09-23 20:16:23

TaskwarriorLinux命令行工具

2015-07-15 10:32:44

Node.js命令行程序

2018-06-12 15:10:11

Linuxvim命令PacVim

2018-11-21 09:57:44

命令行Linux文件

2022-01-26 18:59:08

Python工具

2014-08-25 16:23:24

2018-07-05 08:30:54

Python命令行工具shell

2023-06-09 07:45:29

Kuberneteskubectl

2025-03-18 10:30:44

點(diǎn)贊
收藏

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

久久久xxx| 精品精品国产毛片在线看| 国产精品视频yy9299一区| 国产区精品视频| 欧美日韩在线视频免费| 久本草在线中文字幕亚洲| 日本道精品一区二区三区 | 免费无码不卡视频在线观看| 精品久久久久一区二区三区| 精品一区二区久久久| 欧美精品videossex性护士| 久久久久久九九九九九| 久久久久久久久成人| 欧美午夜片欧美片在线观看| 椎名由奈jux491在线播放| 色欲av永久无码精品无码蜜桃| 日韩精品成人一区二区在线| 久久久久久久久久久亚洲| 无码人妻丰满熟妇啪啪欧美| 白白在线精品| 欧美乱妇23p| 国产精品无码一区二区在线| 二区三区在线观看| 久久久噜噜噜久久人人看| 99超碰麻豆| 一区二区视频免费观看| 日韩视频久久| 欧美日韩国产va另类| 一二三四国产精品| 一区二区三区韩国免费中文网站| 欧美一区二区三区的| 久久综合伊人77777麻豆最新章节| 免费毛片在线看片免费丝瓜视频| 中文无字幕一区二区三区| 精品视频高清无人区区二区三区| 国产99对白在线播放| 日韩av不卡在线观看| 91福利视频网| 日本熟妇色xxxxx日本免费看| 中文字幕一区二区三区欧美日韩| 中文在线资源观看视频网站免费不卡| 艳妇乳肉亭妇荡乳av| 视频二区欧美毛片免费观看| 欧美巨大另类极品videosbest| av7777777| 丰满大乳少妇在线观看网站| 亚洲人成网站精品片在线观看 | 91日韩欧美| 亚洲无线码在线一区观看| 少妇精品一区二区三区| 女仆av观看一区| 亚洲福利视频网站| 国产大尺度视频| 91精品啪在线观看国产爱臀| 精品少妇一区二区三区在线视频| 黄色片子免费看| 99tv成人影院| 4438成人网| 国产传媒免费观看| gogo大尺度成人免费视频| 精品视频1区2区| www.com黄色片| 欧美综合影院| 日韩一区二区三| 国产一精品一aⅴ一免费| 麻豆国产一区| 亚洲福利视频久久| 香蕉视频黄色在线观看| 国产不卡一二三区| 中文字幕日韩综合av| 老司机深夜福利网站| 色综合久久网| 欧美成人午夜免费视在线看片| 91高清免费观看| 欧美日韩亚洲一区三区| 高清欧美电影在线| 色屁屁影院www国产高清麻豆| 天堂午夜影视日韩欧美一区二区| 国产精品成人一区二区| 亚洲图片小说视频| 国产精品一区一区| 国产一区二区自拍| 国产精品久久久久久久龚玥菲 | 国内一区二区视频| 成人18视频| 日韩毛片在线一区二区毛片| 欧美国产精品一区| 不卡中文字幕在线| 久久香蕉av| 色成人在线视频| 天天干天天色天天干| 99精品国产高清一区二区麻豆| 日韩精品在线影院| 国产小视频你懂的| 国内综合精品午夜久久资源| 全亚洲最色的网站在线观看| 91久久国语露脸精品国产高跟| 福利电影一区二区三区| 日本高清一区| 少女频道在线观看高清| 欧美视频在线观看 亚洲欧| 国产一级不卡毛片| 91精品国产自产精品男人的天堂 | 免费在线你懂的| 亚洲成a人v欧美综合天堂| 三级在线视频观看| 成人直播在线观看| 中文综合在线观看| 亚欧视频在线观看| 国产精品自在欧美一区| 欧美中日韩免费视频| 日韩三级电影视频| 在线亚洲+欧美+日本专区| 日韩大尺度视频| 日韩一区电影| 欧日韩在线观看| www黄色在线观看| 国产欧美精品日韩区二区麻豆天美| 国产专区在线视频| 亚洲精品一区三区三区在线观看| 亚洲国产成人精品电影| 久草视频手机在线| 日韩av中文在线观看| 国产麻豆日韩| 最新国产露脸在线观看| 欧美性做爰猛烈叫床潮| 欧美成人三级伦在线观看| 在线精品国产| 成人黄色免费片| 第一视频专区在线| 欧美日韩亚洲一区二| 在线精品视频播放| 天天揉久久久久亚洲精品| 国产精品99导航| 欧美女同网站| 偷拍一区二区三区四区| 日本人dh亚洲人ⅹxx| 天天射—综合中文网| 国产精品91免费在线| 免费av在线电影| 欧美日韩美女在线观看| 免费a在线观看播放| 伊人成年综合电影网| 粉嫩高清一区二区三区精品视频 | 色播五月激情五月| 精品国产一区二区三区av片| 国产91在线播放精品91| 九色网友自拍视频手机在线| 欧美性猛交99久久久久99按摩| 日韩精品人妻中文字幕有码| 亚洲高清电影| 国产一区二区中文字幕免费看| 17videosex性欧美| 亚洲黄色www| 成年人午夜视频| 91蜜桃网址入口| 男人揉女人奶房视频60分| 欧美三级午夜理伦三级在线观看| 68精品久久久久久欧美| 亚洲av成人精品毛片| 欧美日韩免费看| av网在线播放| 久久成人免费网| 欧美另类videos| 日韩中文字幕在线一区| 久久久久久久久电影| 婷婷丁香花五月天| 色偷偷一区二区三区| 欧洲美熟女乱又伦| 精品在线一区二区三区| 亚洲一区 在线播放| 97视频一区| 欧美一区二区三区四区在线| 久久久久久久久亚洲精品| 欧美性欧美巨大黑白大战| 91麻豆精品久久毛片一级| 国产精品一二三四五| 欧美亚洲日本一区二区三区| 久久99国产精品视频| 国产日韩精品入口| 少女频道在线观看免费播放电视剧| 精品国产91乱码一区二区三区| 国产精品美女久久久久av爽| 国产欧美精品日韩区二区麻豆天美| 99热一区二区| 红桃视频国产精品| 欧美日韩精品一区| 亚洲高清影院| 久久青草福利网站| 午夜在线视频| 亚洲精品一区二区三区影院 | 4438x亚洲最大成人网| 国产成人精品亚洲男人的天堂| 久久精品亚洲精品国产欧美| 国产黄色一区二区三区| 西西裸体人体做爰大胆久久久| 亚洲三区视频| 欧洲精品一区| 91精品国产综合久久香蕉最新版| 123区在线| 久久精品国产精品亚洲| 亚洲 欧美 激情 小说 另类| 欧美精品99久久久**| 在线观看免费国产视频| 亚洲婷婷国产精品电影人久久| 在线免费播放av| 国模无码大尺度一区二区三区| 国产又黄又大又粗视频| 中文字幕午夜精品一区二区三区| 青娱乐一区二区| 一区二区三区免费在线看| 国产精品国产三级国产aⅴ9色| 欧美性猛片xxxxx免费中国| 亚洲天堂第二页| 亚洲男人第一天堂| 欧美美女一区二区在线观看| 亚洲图片欧美日韩| 亚洲一区二区三区精品在线| 国产3级在线观看| 久久免费看少妇高潮| 99精品一区二区三区无码吞精 | 丰满岳妇乱一区二区三区| 性色av无码久久一区二区三区| 国产午夜精品一区二区三区四区| 污污免费在线观看| 国产一区二区导航在线播放| 亚洲黄色小视频在线观看| 亚洲一区日韩| 韩日视频在线观看| 欧美激情第10页| 欧美性视频在线播放| 日韩精品免费一区二区三区| 欧洲一区二区在线观看| 欧美一区 二区| 国产精品久久国产精品| 中文字幕亚洲在线观看| 91中文字幕在线| 亚洲色图综合| 成人久久精品视频| 57pao成人永久免费| 国产日韩精品电影| 日韩综合av| 国产自摸综合网| 91精品麻豆| 成人性生交大片免费看视频直播| 韩国理伦片久久电影网| 国产精品偷伦免费视频观看的| 国产另类xxxxhd高清| 国产成人在线精品| 国产精品字幕| 国产欧美日韩91| 亚洲爽爆av| 91黄色精品| 99热这里只有精品首页| 好看的日韩精品| 国产99亚洲| 亚洲精品欧美精品| 97精品一区| 成人短视频在线观看免费| 欧美视频官网| 国产精品333| 久久午夜av| 黄大色黄女片18第一次| 激情国产一区二区| 波多野结衣中文字幕在线播放| 国产成人免费xxxxxxxx| 娇妻高潮浓精白浆xxⅹ| 99国产精品视频免费观看| 右手影院亚洲欧美| 国产精品三级久久久久三级| www.毛片com| 精品欧美aⅴ在线网站| 精品成人无码久久久久久| 欧美日韩国产影片| www.日韩高清| 国产丝袜一区二区三区| 日韩成人影视| 久久久久久999| 日本免费久久| 成人黄色免费网站在线观看| 国产精品超碰| 日韩欧美精品一区二区| 久久久久蜜桃| 久草热视频在线观看| 另类综合日韩欧美亚洲| 日本人妻一区二区三区| 久久久久久久性| 日本精品人妻无码77777| 激情亚洲一区二区三区四区 | 日韩欧美一卡二卡| 青青草av免费在线观看| 久久精品国产欧美亚洲人人爽| 黄色在线观看视频网站| 国产精品99久久久久久www| 国产欧美视频在线| 免费电影一区| 在线成人超碰| 波多野结衣作品集| 成人午夜激情在线| youjizz亚洲女人| 精品国产91久久久久久| 国产精品久久欧美久久一区| 日韩风俗一区 二区| 1区2区在线观看| 国产精品99久久久久久久久久久久 | 亚洲色图都市小说| 国产精品男女视频| 91精品国产欧美日韩| 国产女人在线视频| 久久久亚洲成人| 综合久久av| 日本一区二区在线| 日韩午夜黄色| 久久aaaa片一区二区| 中文字幕第一区| 日本中文字幕在线| 精品国产免费一区二区三区香蕉| 在线免费黄色| 国产精品精品一区二区三区午夜版| 国产精伦一区二区三区| 日本黄色a视频| 青青草国产精品97视觉盛宴| 亚洲精品视频久久久| 亚洲成人中文在线| av av片在线看| www.精品av.com| 国产一区二区主播在线| 久久亚洲高清| aa国产精品| 久久久久久婷婷| 亚洲已满18点击进入久久| 国产色综合视频| 久久精品成人一区二区三区| jizz久久久久久| 神马欧美一区二区| 丝袜亚洲另类欧美| 亚洲av无码一区二区二三区| 污片在线观看一区二区 | 亚洲人精选亚洲人成在线| 成人免费网站观看| 国产精品国产三级国产专区53 | 亚洲婷婷在线视频| 国产精品国产三级国产普通话对白| 亚洲偷熟乱区亚洲香蕉av| 欧洲av不卡| 日本一区精品| 日韩福利视频网| 日本一区二区视频在线播放| 在线观看欧美黄色| 国产鲁鲁视频在线观看免费| 国产精品久久99久久| 精品久久一区| av在线无限看| 国产精品久久久久四虎| 一本一道人人妻人人妻αv| www.久久久久| 精品国产三级| 97在线国产视频| av在线不卡电影| 黄色片免费观看视频| 亚洲欧美在线播放| 午夜无码国产理论在线| 亚欧洲精品在线视频免费观看| 奇米综合一区二区三区精品视频| 欧美xxxx精品| 欧美一区二区三区啪啪| 国产在线xxx| 玖玖玖精品中文字幕| 欧美96一区二区免费视频| 三级黄色在线观看| 精品嫩草影院久久| 涩涩视频在线| 亚洲精品视频一区二区三区| 国产麻豆一精品一av一免费| 伊人365影院| 国产亚洲精品久久| 国产不卡精品在线| 成人午夜精品久久久久久久蜜臀| www日韩大片| 一级黄在线观看| 欧美激情三级免费| 精品99在线| 日韩精品――色哟哟| 日韩欧美亚洲国产一区| caoporn国产精品免费视频| 亚洲精品欧美日韩| 国产亚洲网站| 人人澡人人澡人人看| 亚洲护士老师的毛茸茸最新章节| 国产美女久久| 久久久久久久久久网| 国产精品久久看| 色哟哟中文字幕| 国产一区二区丝袜| 国产日韩欧美三区| 欧美一级片在线视频| 日韩精品极品毛片系列视频| 99久久久国产| 国产成人av影视| 亚洲一区二区五区|