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

如何構(gòu)建自動(dòng)化的前端開發(fā)流程

開發(fā) 前端 自動(dòng)化
構(gòu)建一個(gè)自動(dòng)化的前端開發(fā)流程是非常必要的,但現(xiàn)在前端開發(fā)流程的構(gòu)建是百花齊放,沒有一個(gè)統(tǒng)一的標(biāo)準(zhǔn),還有很多依賴于后端的架構(gòu)來做前端開發(fā)管理。

如今的前端開發(fā)中,已經(jīng)不再只是一些簡單的靜態(tài)文件了,對(duì)于很多Web App來說,前端代碼甚至比后端代碼要更加復(fù)雜,更加難于管理,例如:

  • 我們有許多的第三方庫的依賴需要管理;
  • 我們有獨(dú)立的前端測(cè)試需要自動(dòng)運(yùn)行;
  • 我們還有很多代碼需要在發(fā)布時(shí)進(jìn)行打包壓縮;
  • ⋯⋯

所以構(gòu)建一個(gè)自動(dòng)化的前端開發(fā)流程是非常必要的,但現(xiàn)在前端開發(fā)流程的構(gòu)建是百花齊放,沒有一個(gè)統(tǒng)一的標(biāo)準(zhǔn),還有很多依賴于后端的架構(gòu)來做前端開發(fā)管理。例如在Rails開發(fā)中,就有各種前端庫的gem包。但是這種依賴于后端框架的管理方式有許多問題:

  • 許多gem包的維護(hù)者并不是前端庫的維護(hù)者,所以更新不一定即時(shí);
  • 不利于前端代碼與后端代碼做分離;
  • 增加了前端開發(fā)者的學(xué)習(xí)和使用成本;
  • ⋯⋯

 

[[84676]]

于是現(xiàn)在出現(xiàn)了一些不依賴于后端代碼(雖然還是要依賴Node.js⋯⋯)的管理工具,對(duì)于前端開發(fā)者非常友好,例如:YEMAN、Jam、volo、component、Brunch⋯⋯但是這些工具都或多或少有自己的一些問題,所以我決定用一些更輕量的工具(bower、grunt)來搭建自己的前端開發(fā)流程。本文的例子來自本人正在開發(fā)的一個(gè)項(xiàng)目,可以在github上查看所有的代碼。

什么是開發(fā)流程?

在我看來一個(gè)完整的開發(fā)流程應(yīng)該包括:

  • 本地開發(fā)環(huán)境的初始化
  • 第三方依賴的管理
  • 源文件編譯
  • 自動(dòng)化測(cè)試
  • 發(fā)布到pipeline和各個(gè)環(huán)境

而現(xiàn)代的開發(fā)流程,就是要使上面的各個(gè)部分都可以自動(dòng)化,一個(gè)命令就可以使這些流程都自動(dòng)走完,并且快速的得到錯(cuò)誤或通過的反饋,讓我們可以方便快速的修復(fù)錯(cuò)誤和release。

本地開發(fā)環(huán)境的初始化

這里我使用的工具是Node.js和NPM,它們都基于JavaScript,使用Json來配置,對(duì)于前端開發(fā)人員非常友好。

安裝完成Node.js和NPM后,在項(xiàng)目根目錄下創(chuàng)建NPM的配置文件package.json

  1.     "name": "Project Name", 
  2.     "version": "0.0.1", 
  3.     "description": "Project Description", 
  4.     "repository": { 
  5.         "type": "git", 
  6.         "url": "git://github.com/path/to/your_project" 
  7.     }, 
  8.     "author": "Author Name", 
  9.     "license": "BSD", 
  10.     "readmeFilename": "README.md", 
  11.     "gitHead": "git head", 
  12.     "devDependencies": { 
  13.         "grunt": "latest", 
  14.         "grunt-contrib-connect": "latest", 
  15.         "grunt-contrib-concat": "latest", 
  16.         "grunt-contrib-jasmine": "latest", 
  17.         "grunt-contrib-watch": "latest", 
  18.         "grunt-contrib-compass": "latest" 
  19.     } 

其中最重要的一個(gè)配置項(xiàng)是devDependencies,這是用于開發(fā)的依賴,例如:自動(dòng)化測(cè)試、源文件編譯等等,其中各個(gè)依賴的作用和用法將會(huì)在后面講到。而前端生產(chǎn)代碼的依賴會(huì)使用另一個(gè)工具來管理,也在后面講到。創(chuàng)建完成以后運(yùn)行npm install,NPM就會(huì)將這些依賴都安裝到項(xiàng)目根目錄的node_modules文件夾中。

第三方依賴的管理

這里我使用的工具是bower。 其實(shí)NPM也可以管理,但是NPM并不是讀取第三方依賴原始的repository,而是讀取自己管理的一個(gè)repository,所以更新可能會(huì)慢點(diǎn), 并且它使用CommonJS的接口方便Node.js項(xiàng)目的開發(fā),并不是針對(duì)純前端開發(fā)的項(xiàng)目;而bower是讀取原始的github repository,沒有更新延遲的問題,所有包都是針對(duì)純前端開發(fā)項(xiàng)目的。

要使用bower只需要簡單的三步:

  1. 安裝:npm install bower -g
  2. 在項(xiàng)目根目錄中創(chuàng)建配置文件.bowerrc
  3. 在項(xiàng)目根目錄中創(chuàng)建依賴配置文件components.json

我們首先來看看.bowerrc的內(nèi)容:

  1.     "directory" : "components", 
  2.     "json"      : "component.json", 
  3.     "endpoint"  : "https://bower.herokuapp.com" 

其中directory指定了所有的依賴會(huì)被安裝到哪里;json指定了依賴配置文件的路徑;endpoint制定了依賴的repository的尋址服務(wù)器,你可以替換為自己的尋址服務(wù)器。

然后我們來看看components.json的內(nèi)容:

  1.     "name": "Project Name", 
  2.     "version": "0.0.1", 
  3.     "dependencies": { 
  4.       "jquery": "latest", 
  5.       "underscore": "latest", 
  6.       "backbone": "latest", 
  7.       "jasmine-jquery": "latest", 
  8.       "jasmine-ajax": "git@github.com:pivotal/jasmine-ajax.git" 
  9.     } 

其中最重要的就是dependencies,它指定了所有前端開發(fā)依賴的包。所有bower包含的依賴都可以在這里查到,對(duì)于bower沒有包含的依賴也可以直接指定github的repository,例如:"jasmine-ajax": "git@github.com:pivotal/jasmine-ajax.git"

最后運(yùn)行bower install就可以在components文件夾中看到所有第三方依賴的文件了。但是bower有一個(gè)問題,就是它將所有g(shù)ithub repository中的文件都下載下來了,其中有許多是我們不需要的文件。下面我們會(huì)將我們需要的文件提取出來打包放到我們指定的目錄中。

#p#

源文件編譯

這里我使用的工具是grunt,他本身主要是基于Node.js的文件操作包,其中有許多插件可以讓我們完成js文件的compile和compress、sass到css的轉(zhuǎn)換等等操作。要使用它需要先安裝命令行工具:npm install grunt-cli -g,然后在項(xiàng)目根目錄中創(chuàng)建文件Gruntfile.js,這個(gè)文件用于定義各種task,我們首先定義一個(gè)task將從bower下載的第三方依賴都打包到文件app/js/lib.js中:

  1. module.exports = function(grunt) { 
  2.     var dependencies = [ 
  3.         'components/jquery/jquery.js', 
  4.         'components/underscore/underscore.js', 
  5.         'components/backbone/backbone.js']; 
  6.     grunt.initConfig({ 
  7.         concat: { 
  8.             js: { 
  9.                 src: dependencies, 
  10.                 dest: 'app/js/lib.js' 
  11.             } 
  12.         } 
  13.     }); 
  14.     grunt.loadNpmTasks('grunt-contrib-concat'); 
  15. }; 

這里的grunt-contrib-concat就是grunt的一個(gè)插件,用于文件的合并操作,我們已經(jīng)在前面的package.json中引入了。js是task name;src指定了合并的源文件地址;dest指定了合并的目標(biāo)文件。這樣當(dāng)我們運(yùn)行grunt concat:js后,所有的依賴文件都會(huì)被合并為app/js/lib.js。這樣做的好處是我們可以控制每個(gè)依賴的引入順序,但是麻煩的是每次引入新的依賴都需要手動(dòng)加入到dependencies數(shù)組中。這個(gè)暫時(shí)沒有更好的解決方案,因?yàn)椴皇撬械陌荚谧约旱?code>components.js中聲明了main文件,很多時(shí)候必須自己手動(dòng)指定。

JavaScript文件編譯完成以后就是CSS文件,在現(xiàn)代的前端開發(fā)中,我們已經(jīng)很少直接寫CSS文件了,一般都使用SASS或者LESS。grunt也提供了這種支持,這里我使用的是grunt-contrib-compass:

  1. module.exports = function(grunt) { 
  2.     var sasses = 'sass'
  3.     grunt.initConfig({ 
  4.         compass: { 
  5.             development: { 
  6.                 options: { 
  7.                     sassDir: sasses, 
  8.                     cssDir: 'app/css' 
  9.                 } 
  10.             } 
  11.         } 
  12.     }); 
  13.     grunt.loadNpmTasks('grunt-contrib-compass'); 
  14. }; 

然后運(yùn)行grunt compass:development就可以完成CSS文件的編譯了。

自動(dòng)化測(cè)試

這里我使用的自動(dòng)化測(cè)試工具是Jasmine,它grunt中同樣有一個(gè)插件:grunt-contrib-jasmine。下面我們來看看如何在Gruntfile.js中定義測(cè)試的task:

  1. module.exports = function(grunt) { 
  2.     var sources = 'app/js/**/*.js'
  3.         specs = 'spec/**/*Spec.js'
  4.     grunt.initConfig({ 
  5.         jasmine: { 
  6.             test: { 
  7.                 src: [sources], 
  8.                 options: { 
  9.                     specs: specs, 
  10.                     helpers: ['spec/helper/**/*.js'], 
  11.                     vendor: 'app/js/lib.js' 
  12.                 } 
  13.             } 
  14.         } 
  15.     }); 
  16.     grunt.loadNpmTasks('grunt-contrib-jasmine'); 
  17. }; 

配置完成以后就可以運(yùn)行grunt jasmine:test來跑測(cè)試,但問題是每次寫完代碼都要手動(dòng)執(zhí)行一次非常麻煩,最好可以每次代碼有更改都自動(dòng)跑一次,讓我們可以更快的得到反饋。grunt的watch插件就提供了這種支持:

  1. module.exports = function(grunt) { 
  2.     var sources = 'app/js/**/*.js'
  3.         specs = 'spec/**/*Spec.js'
  4.     grunt.initConfig({ 
  5.         jasmine: { 
  6.             test: { 
  7.                 src: [sources], 
  8.                 options: { 
  9.                     specs: specs, 
  10.                     helpers: ['spec/helper/**/*.js'], 
  11.                     vendor: 'app/js/lib.js' 
  12.                 } 
  13.             } 
  14.         }, 
  15.         watch: { 
  16.             test: { 
  17.                 files: [sources, specs], 
  18.                 tasks: ['jasmine:test'] 
  19.             } 
  20.         } 
  21.     }); 
  22.     grunt.loadNpmTasks('grunt-contrib-jasmine'); 
  23.     grunt.loadNpmTasks('grunt-contrib-watch'); 
  24. }; 

files指定了需要監(jiān)聽變動(dòng)的文件;tasks指定了修改后自動(dòng)觸發(fā)的task。現(xiàn)在只要我們運(yùn)行grunt watch:test,那么有任何源文件、測(cè)試文件的改動(dòng),Jasmine測(cè)試都會(huì)自動(dòng)運(yùn)行了。有時(shí)候我們也希望測(cè)試的結(jié)果顯示在網(wǎng)頁上,便于我們做js的調(diào)試。那么可以將tasks:['jasmine:test']改為tasks: ['jasmine:test:build'],然后打開根目錄下的_SpecRunner.html文件,就可以在網(wǎng)頁中看到測(cè)試結(jié)果了,再加上一些Chrome的Livereload插件,就可以不用刷新實(shí)時(shí)的看到測(cè)試結(jié)果,效率非常之高。雖然grunt插件中也有l(wèi)ivereload,但是與grunt-contrib-watch無法很好的集成,所以我沒有使用這種方式。

CI Pipeline

由于我的項(xiàng)目是host在github上,所以我選擇travis-ci作為我的CI服務(wù)器。要啟用travis-ci需要以下幾步:

  1. 在travis-ci中注冊(cè)一個(gè)賬號(hào),獲取一個(gè)token;
  2. 在你的github項(xiàng)目的Settings–>Service Hooks中找到Travis,填入token并且啟用;
  3. 回到travis-ci,在Accounts–>Repositories中打開你的項(xiàng)目的service hook
  4. Push一個(gè).travis.yml到github,觸發(fā)第一次build。
  5. 修改package.jsonscripts項(xiàng),指定運(yùn)行測(cè)試的命令

下面我們來看看如何配置.travis.yml

  1. language: node_js 
  2. node_js: 
  3.   - "0.8" 
  4. before_script: 
  5.   - npm install -g grunt-cli 

由于我們的環(huán)境是基于Node.js搭建的,所以在language設(shè)置了nodejs;而**nodejs指定了Node.js的版 本;before_script**指定了在測(cè)試運(yùn)行前需要執(zhí)行的命令,由于我們的腳本都是基于grunt的,所以需要先安裝grunt的命令行包。

然后再修改package.json

  1.     ⋯⋯ 
  2.     "scripts": { 
  3.         "test": "grunt jasmine:test" 
  4.     } 
  5.     ⋯⋯ 

將修改以后的package.jsonpush到github上,再次觸發(fā)一個(gè)新的build,你可以看到你之前錯(cuò)誤的build已經(jīng)綠了。

這里還有一個(gè)小提示:如何讓build狀態(tài)顯示在項(xiàng)目的readme中?很簡單,只需要在README.md中加入以下代碼就可以了:

  1. [![Build Status](https://travis-ci.org/path/to/your_repository.png?branch=master)](http://travis-ci.org/path/to/your_repository) 

到這里基本的環(huán)境搭建就完成了,當(dāng)然我們還可以使用grund的registerTask來定義一個(gè)任務(wù)序列,還可以加 入template的編譯⋯⋯這些都可以通過grunt來靈活設(shè)置。最重要的是現(xiàn)在別人拿到一個(gè)項(xiàng)目的代碼以后,可以通過一些命令來快速的搭建本地環(huán)境, 方便的進(jìn)行測(cè)試和開發(fā),而且沒有依賴與后端的開發(fā)環(huán)境,只要定義好接口,前端開發(fā)可以完全獨(dú)立開了。雖然這其中還有很多問題沒有解決,例如:

  • 如何讓第三方依賴自申明main文件
  • package.jsoncomponents.json其實(shí)有些重復(fù)
  • Live Reload還需要Chrome插件才能完成
  • ⋯⋯

這正是由于現(xiàn)在前端開發(fā)環(huán)境還沒有后端開發(fā)的那種標(biāo)準(zhǔn)化,也正是挑戰(zhàn)和機(jī)遇之所在!

原文鏈接:http://www.zation.me/2013/03/15/how-to-build-frontend-dev-env.html

責(zé)任編輯:陳四芳 來源: zation.me
相關(guān)推薦

2022-07-08 11:18:33

前端實(shí)踐自動(dòng)化

2021-05-27 08:00:00

自動(dòng)化機(jī)器人工具

2020-12-08 06:20:49

前端重構(gòu)Vue

2012-09-04 10:20:31

IBMdw

2021-10-14 06:52:47

自動(dòng)化開發(fā)環(huán)境

2020-04-29 11:28:54

智能自動(dòng)化機(jī)器人流程自動(dòng)化AI

2023-01-04 13:41:23

RPA自動(dòng)化機(jī)器人

2017-01-16 13:38:05

前端開發(fā)自動(dòng)化

2024-07-04 17:34:48

RPAAI驅(qū)動(dòng)

2020-09-22 09:46:11

機(jī)器人流程自動(dòng)化RPA流程

2012-11-23 14:28:45

IBMdW

2024-08-23 10:31:14

2021-09-07 10:43:16

人工智能AI深度學(xué)習(xí)

2022-09-14 10:00:12

前端自動(dòng)化測(cè)試

2015-06-09 13:45:14

2023-04-06 07:09:25

自動(dòng)化部署Actions

2022-03-07 11:09:36

自動(dòng)化企業(yè)技術(shù)

2023-09-13 11:40:12

2021-04-28 16:49:27

自動(dòng)化設(shè)備制藥

2013-05-02 13:02:59

開發(fā)環(huán)境自動(dòng)化團(tuán)隊(duì)
點(diǎn)贊
收藏

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

91看片破解版| 资源网第一页久久久| 毛片毛片女人毛片毛片| 国内精品伊人久久久| 欧美色图一区二区三区| 国产精品88久久久久久妇女| 天堂中文网在线| 秋霞av亚洲一区二区三| 久久亚洲影音av资源网| jlzzjizz在线播放观看| 国产精品伊人| 午夜视频一区二区三区| 特级西西444www大精品视频| www.久久色| 久久亚洲精品伦理| 久久高清视频免费| 欧美狂猛xxxxx乱大交3| 国产欧美日韩电影| 日本乱码高清不卡字幕| 久久久久久av无码免费网站下载| 午夜小视频免费| 久久人人精品| 久久av中文字幕| 三级黄色片网站| 麻豆一区在线| 欧美无乱码久久久免费午夜一区 | 午夜精品久久久久久久96蜜桃| 99视频在线精品国自产拍免费观看| 综合欧美国产视频二区| 国产成人无码一区二区在线观看| 99精品视频在线免费播放| 亚洲国产精品久久久久秋霞影院 | 色婷婷综合久久| 男人c女人视频| 午夜激情在线观看| 久久久欧美精品sm网站| 国产精品久久久久久久久久直播| 国产精品国产三级国产aⅴ| 久久精品女人| 91高潮在线观看| 国产一级在线播放| 亚洲草久电影| 日韩在线观看成人| 亚洲av成人无码久久精品| 欧美激情极品| 亚洲成人激情在线观看| 国产高清999| 老司机精品视频网| 欧美色综合网站| 妺妺窝人体色www在线观看| 麻豆免费在线| 懂色av影视一区二区三区| 996这里只有精品| caoporn97在线视频| 亚洲欧美在线高清| 中文字幕久久一区| 国产在线二区| 欧美中文在线免费| 日日碰狠狠躁久久躁婷婷| 成人女同在线观看| 亚洲午夜精品网| 亚洲色婷婷久久精品av蜜桃| 国产精品刘玥久久一区| 亚洲欧美日韩中文播放| 欧美日韩一级在线| 性欧美video高清bbw| 亚洲精品成人悠悠色影视| 一二三在线视频| 日韩激情美女| 五月天婷婷综合| www.亚洲天堂网| 国产91欧美| 91精品国产综合久久婷婷香蕉 | 日韩av在线一区二区三区| 欧美在线观看在线观看| 久久久www免费人成精品| 日本一区二区三区免费观看| 91精品专区| 亚洲精品中文在线观看| 国产日韩视频在线播放| 黄色网页在线观看| 亚洲国产另类精品专区| 欧洲av无码放荡人妇网站| 午夜激情成人网| 欧美绝品在线观看成人午夜影视| 亚洲AV无码久久精品国产一区| 亚洲精选av| 日韩理论片久久| 九一在线免费观看| 欧美久久一区| 日韩av电影在线网| 国产女18毛片多18精品| av在线播放一区二区三区| 日韩av影视| 欧美理论电影| 在线免费观看不卡av| 涩多多在线观看| 日韩av三区| 久久精品国产电影| 日韩免费一二三区| 免费成人在线影院| 国产日韩一区欧美| 国产福利在线观看| 亚洲国产美国国产综合一区二区| 欧美综合在线观看视频| 日韩视频在线直播| 欧美一区二区三区电影| 美女久久久久久久久久| 欧美视频亚洲视频| 国产精品久久中文| 神马久久久久| 亚洲精品国产a| 亚洲天堂网一区| 欧美色图婷婷| 欧美大奶子在线| www.色国产| 成人av在线网| 少妇高潮大叫好爽喷水| 日韩av中字| 亚洲国产天堂久久综合网| 九九热视频在线免费观看| 国产精品普通话对白| 在线中文字幕不卡| 欧美日本亚洲| 国产第一页在线| 欧美精品三级日韩久久| 韩国女同性做爰三级| 亚洲青涩在线| 亚洲自拍欧美色图| 婷婷在线视频观看| 在线观看精品一区| 中国美女乱淫免费看视频| 亚洲私拍自拍| 91视频网页| 国产在线观看免费麻豆| 欧美视频在线观看一区二区| 99精品一区二区三区无码吞精 | 成人免费高清在线| 综合久久国产| 日韩成人精品一区二区三区| 亚洲欧美激情一区| av中文在线播放| 91在线高清观看| 精品久久久久久久久久中文字幕| 欧美1区2区3| 美女福利视频一区| 国产女无套免费视频| 成人欧美一区二区三区黑人麻豆| 国产一二三四在线视频| 成人久久一区| 国产精品偷伦视频免费观看国产| 国产精品一区二区婷婷| 在线观看视频一区| 日本爱爱爱视频| 日本欧美一区二区三区乱码| 日韩免费电影一区二区| av在线一区不卡| 色爱av美腿丝袜综合粉嫩av| 亚洲中文无码av在线| 国产视频一区二区三区在线观看| 精品久久久久久久无码| 日本精品黄色| 91麻豆国产精品| 色黄网站在线观看| 亚洲成人av中文字幕| 色网站在线播放| 久久久精品欧美丰满| 动漫av免费观看| 日韩精品欧美激情一区二区| 成人写真福利网| 欧美巨大xxxx做受沙滩| 亚洲国产欧美自拍| 一级久久久久久| 日韩码欧中文字| 日批视频免费看| 国产亚洲在线观看| 五月天久久综合网| 日韩成人在线看| 欧洲日韩成人av| 91精彩在线视频| 日韩午夜小视频| 日本中文字幕在线免费观看| 久久久噜噜噜久久中文字幕色伊伊 | 黄网动漫久久久| 日本高清黄色片| 国内久久婷婷综合| 欧美精品自拍视频| 欧美性感美女一区二区| 51精品国产人成在线观看| 国精一区二区三区| 在线精品视频视频中文字幕| 精品人妻一区二区三区日产乱码| 午夜a成v人精品| 992在线观看| 99在线热播精品免费| 特级丰满少妇一级| 伊人久久综合| 亚洲欧洲精品一区二区| 波多野结衣在线一区二区| 国产成人亚洲综合青青| 三级资源在线| 最近2019年好看中文字幕视频 | 水蜜桃在线免费观看| 免费观看成人www动漫视频| 国产精品一区二区性色av| 欧美人动性xxxxz0oz| 伊人亚洲福利一区二区三区| 亚洲国产日韩在线观看| 欧美日韩你懂得| 国产视频91在线| 亚洲精品成人悠悠色影视| 老熟妇一区二区| www.亚洲免费av| 手机在线视频一区| 日韩国产欧美三级| 国产美女网站在线观看| 伊人久久大香线蕉综合四虎小说 | 99久久久国产精品美女| 久久国产精品亚洲va麻豆| 国产精品亚洲综合在线观看 | 国产又大又粗又爽| 亚洲一区av在线| 久久国产精品国语对白| 欧美国产禁国产网站cc| 国产精品探花一区二区在线观看| 国产一区二区三区久久久| 999精品视频在线| 欧美一级网站| 无码人妻丰满熟妇区96| 欧美日韩国产探花| 天堂av在线中文| 亚洲久久久久| 一区二区三区四区五区视频| 九色精品国产蝌蚪| 精品九九九九| 伦理一区二区| 国产精品日韩一区二区免费视频| 国产一区二区三区免费在线| 国产精品视频永久免费播放| 欧洲一区二区三区精品| 日韩美女视频免费看| 涩涩视频在线| 日本国产欧美一区二区三区| 热三久草你在线| 91chinesevideo永久地址| 操喷在线视频| 性欧美xxxx交| 午夜伦理福利在线| 热门国产精品亚洲第一区在线| 无码小电影在线观看网站免费| 91av国产在线| 黑人巨大精品| 国产91在线播放九色快色| 亚洲www啪成人一区二区| 国产精品av在线| 欧美日韩国产网站| 成人精品一区二区三区电影黑人| 一区在线不卡| 亚洲综合精品伊人久久| 日韩欧美中文字幕一区二区三区| 成人黄视频免费| 麻豆成人入口| 日本一区二区久久精品| 日本道不卡免费一区| 国产又大又长又粗又黄| 欧美大片一区| 免费看国产曰批40分钟| 噜噜噜久久亚洲精品国产品小说| 国产精品无码一本二本三本色| 六月丁香综合在线视频| 色男人天堂av| 99视频在线观看一区三区| 欧洲美一区二区三区亚洲| 国产精品久线在线观看| 欧美日韩人妻精品一区二区三区| 亚洲国产精品一区二区尤物区| 久久国产视频播放| 欧美日韩高清在线播放| 亚洲AV无码乱码国产精品牛牛| 亚洲护士老师的毛茸茸最新章节| 国际av在线| 久久国产精品久久国产精品| 日本在线啊啊| 国产在线精品一区免费香蕉 | 久久国产精品一区二区| 97免费公开视频| 国产视频一区二区在线| 九九九在线视频| 91久久精品一区二区三| 国产乱子伦精品无码码专区| 亚洲国产欧美在线成人app| 9色在线视频网站| 久久久久久国产精品| 91国内外精品自在线播放| 99久热re在线精品996热视频| 亚洲人成网亚洲欧洲无码| 99亚洲精品视频| 亚洲综合社区| 亚洲午夜精品在线观看| 久久久久久久久99精品| 欧美精品乱码视频一二专区| 日本高清不卡视频| 亚洲精品一区二区三区四区| 国产亚洲在线播放| av漫画网站在线观看| 成人激情视频在线| 九热爱视频精品视频| 日韩精品综合在线| 蜜桃视频在线一区| 日韩片在线观看| 亚洲图片欧美综合| 国产精品久久久久久久久毛片 | h片在线免费观看| 国产成人精品久久二区二区91| 1204国产成人精品视频| 在线观看成人av| 日韩av高清在线观看| 超碰男人的天堂| 亚洲综合成人网| 97在线播放免费观看| 在线成人激情视频| 日韩大尺度黄色| 国模一区二区三区私拍视频| 91精品国产91久久综合| 亚洲欧美日韩一级| 久久婷婷成人综合色| 国产尤物在线视频| 亚洲国产一区二区三区四区| 色yeye免费人成网站在线观看| 国产中文欧美精品| 日本成人小视频| 国产真人无码作爱视频免费| 2014亚洲片线观看视频免费| 日本午夜小视频| 亚洲国产成人一区| 毛片网站在线看| 999在线免费观看视频| 亚洲精品a级片| 网站在线你懂的| 最新欧美精品一区二区三区| 中文天堂在线播放| 神马久久久久久| 成人豆花视频| 一本二本三本亚洲码| 国产一区二区三区在线观看免费| 很污很黄的网站| 欧美一区二区三区在线观看| 久久精品视频观看| 亚洲free性xxxx护士hd| 欧美一区不卡| 日本天堂在线播放| 亚洲国产精品久久不卡毛片| 三级网站免费观看| 欧美亚洲伦理www| 神马影视一区二区| 天天操天天爽天天射| 国产精品视频一二三区| 一级黄在线观看| 欧美成人免费一级人片100| 日本久久伊人| 成人一区二区免费视频| av不卡免费在线观看| 9i精品福利一区二区三区| 伊人成人开心激情综合网| 日韩欧美激情| 69精品丰满人妻无码视频a片| 成人aa视频在线观看| 日韩色图在线观看| 中文字幕精品在线| 久久久久久亚洲精品美女| 中文字幕色呦呦| av在线不卡观看免费观看| 亚洲自拍一区在线观看| 日韩在线资源网| ady日本映画久久精品一区二区| 国产精品无码一区二区在线| 国产亚洲精久久久久久| 亚洲天堂久久久久| 久久久久久久久综合| 你懂的视频欧美| 天天久久综合网| 懂色aⅴ精品一区二区三区蜜月 | 蜜月aⅴ免费一区二区三区 | 涩涩视频在线播放| 亚洲欧美一区二区原创| 国产高清一区日本| 日韩久久中文字幕| www国产精品视频| 牛牛影视久久网| 亚洲免费看av| 亚洲成人一区在线| 91在线导航| 成人在线看片| 日韩高清一区二区| 久草资源在线视频| 国产一区二区动漫| 成人动态视频| 亚洲美女性囗交| 精品国产91久久久久久| 日本中文字幕在线看|