成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

Vue結合Springboot實現用戶列表單頁面(前后端分離)

瀏覽:2日期:2022-09-28 10:14:48
目錄用戶列表頁面開發項目介紹1、前端html頁面編寫2、springboot框架搭建2.1、項目創建2.2、連接數據庫2.3、項目完整依賴3、編寫entity層4、查詢用戶信息4.1、后端代碼編寫4.2、前端代碼編寫5、添加用戶信息5.1、后端代碼編寫5.2、前端代碼編寫6、修改用戶信息6.1、后端代碼6.2、前端代碼7、刪除用戶信息7.1、后端代碼7.2、前端代碼用戶列表頁面開發項目介紹

用戶列表頁面開發,可以實現簡單的查詢,刪除,修改,和添加用戶信息功能。前端使用vue框架,后端使用springboot框架,一個簡單的vue+springboot前后端分離小項目。

本項目主要模塊及技術點如圖

Vue結合Springboot實現用戶列表單頁面(前后端分離)

項目源碼+筆記+資料

vue-springboot_jb51.rar

1、前端html頁面編寫

頁面:

Vue結合Springboot實現用戶列表單頁面(前后端分離)

代碼:

<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>vue系列課程</title> <!-- 最新版本的 Bootstrap 核心 CSS 文件 --> <link rel='stylesheet' rel='external nofollow' ></head><body> <div id='app'><div class='container-fluid'> <!--標題行--> <div class='row'><div class='col-sm-6 col-sm-offset-3'><h1 class='text-center'>用戶列表</h1></div> </div> <!--數據行--> <div class='row'><div class='col-sm-10 col-sm-offset-1'> <!--添加按鈕--> <a href='http://www.piao2010.com/bcjs/10029.html' class=' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' btn-success btn-sm'>添加</a> <!--列表--> <table style='margin-top: 10px;'><tr> <td>編號</td> <td>姓名</td> <td>工資</td> <td>年齡</td> <td>個人簡介</td> <td>操作</td></tr><tr v-for='user in users'> <td>{{user.id}}</td> <td>{{user.name}}</td> <td>{{user.salary}}</td> <td>{{user.age}}</td> <td>{{user.description}}</td> <td><a href='http://www.piao2010.com/bcjs/10029.html' class=' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' btn btn-danger btn-sm'>刪除</a><a href='http://www.piao2010.com/bcjs/10029.html' class=' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' btn btn-info btn-sm'>修改</a> </td></tr> </table> <!--添加 和 修改表單--> <form><div class='form-group'> <label class='control-label'>編號</label> <div ><p class='form-control-static'>0001</p> </div></div><div class='form-group'> <label for='name'>姓名</label> <input type='text' placeholder='請輸入姓名'></div><div class='form-group'> <label for='salary'>工資</label> <input type='text' placeholder='請輸入工資'></div><div class='form-group'> <label for='age'>年齡</label> <input type='text' placeholder='請輸入年齡'></div><div class='form-group'> <label for='description'>個人簡介</label> <input type='text' placeholder='請輸入個人簡介'></div><button type='submit' class='btn btn-primary'>Submit</button> </form></div> </div></div> </div></body></html><!--引入axios--><script src='http://www.piao2010.com/bcjs/js/axios.min.js'></script><!--引入vue--><script src='http://www.piao2010.com/bcjs/js/vue.js'></script><script> var app = new Vue({el: '#app',data:{ msg:'vue 生命周期', users:[],},methods:{},computed:{},created(){ //發送axios請求 /*axios.get('http://localhost:8989/users').then(res=>{ this.users = res.data; });*/ this.users =[{id:1,name:'小陳',age:23,salary:2300,description:'他是一個小白!!!'}]}, });</script>

我們將html頁面放到如下位置:

Vue結合Springboot實現用戶列表單頁面(前后端分離)

js目錄下存放vue和axios資源文件。

2、springboot框架搭建2.1、項目創建

1、新建maven項目,取名為vue_day3_admin

Vue結合Springboot實現用戶列表單頁面(前后端分離)

2、引入sprinboot-web依賴

<dependencies> <!--引入springboot-web依賴--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId> </dependency></dependencies>

3、編寫啟動類AdminApplication

package com.xiao;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplicationpublic class AdminApplication { public static void main(String[] args) {SpringApplication.run(AdminApplication.class,args); }}

4、測試

Vue結合Springboot實現用戶列表單頁面(前后端分離)

2.2、連接數據庫

1、創建vue_day3數據庫

CREATE TABLE t_user(id INT(6) PRIMARY KEY AUTO_INCREMENT,NAME VARCHAR(40),salary DOUBLE(7,2),age INT(3),des VARCHAR(200));

2、引入數據庫相關依賴

<!--整合mybatis 引入依賴--><dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version></dependency><!--mysql--><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>5.1.38</scope></dependency><!--druid--><dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.1</version></dependency></dependencies>

3、application.properties配置文件編寫

server.port=8990# 整合mybatisspring.datasource.type=com.alibaba.druid.pool.DruidDataSourcespring.datasource.driver-class-name=com.mysql.jdbc.Driverspring.datasource.url=jdbc:mysql://localhost:3306/vue_day3?characterEncoding=utf-8spring.datasource.username=rootspring.datasource.password=root# 指定mapper出現的位置mybatis.mapper-locations=classpath:com/xiao/mapper/*.xmlmybatis.type-aliases-package=com.xiao.entity# 展示執行過程中sql語句logging.level.com.xiao.dao=debug

4、springboot連接mysql數據庫

4.1、打開Data Sources and Deivers 輸入數據庫user和password,并選擇要連接的數據庫。

Vue結合Springboot實現用戶列表單頁面(前后端分離)

4.2、設置時區為UTC

Vue結合Springboot實現用戶列表單頁面(前后端分離)

5、啟動測試一下

Vue結合Springboot實現用戶列表單頁面(前后端分離)

沒有任何問題。

2.3、項目完整依賴

<?xml version='1.0' encoding='UTF-8'?><project xmlns='http://maven.apache.org/POM/4.0.0' xmlns:xsi='http://www.w3.org/2001/XMLSchema-instance' xsi:schemaLocation='http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd'> <modelVersion>4.0.0</modelVersion> <groupId>org.example</groupId> <artifactId>vue_day3_admin</artifactId> <version>1.0-SNAPSHOT</version> <!--繼承springboot父項目--> <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.5.0</version> </parent> <dependencies><!--引入springboot-web依賴--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!--整合mybatis 引入依賴--><dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.1.3</version></dependency><!--mysql--><dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <scope>5.1.38</scope></dependency><!--druid--><dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.2.1</version></dependency><!--本地測試--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <version>1.5.12.RELEASE</version> <scope>test</scope></dependency> </dependencies></project>3、編寫entity層

創建user實體類

package com.xiao.entity;public class User { private Integer id; private String name; private Double salary; private Integer age; private String des; public User() { } public User(Integer id, String name, Double salary, Integer age, String des) {this.id = id;this.name = name;this.salary = salary;this.age = age;this.des = des; } public Integer getId() {return id; } public void setId(Integer id) {this.id = id; } public String getName() {return name; } public void setName(String name) {this.name = name; } public Double getSalary() {return salary; } public void setSalary(Double salary) {this.salary = salary; } public Integer getAge() {return age; } public void setAge(Integer age) {this.age = age; } public String getDes() {return des; } public void setDes(String des) {this.des = des; } @Override public String toString() {return 'User{' +'id=' + id +', name=’' + name + ’’’ +', salary=' + salary +', age=' + age +', des=’' + des + ’’’ +’}’; }}4、查詢用戶信息4.1、后端代碼編寫

1、UserDAO編寫

package com.xiao.dao;import com.xiao.entity.User;import java.util.List;public interface UserDAO { //查詢所有用戶信息 List<User> findAll();}

2、UserDAOMapper.xml編寫

在resources下創建如下目錄

Vue結合Springboot實現用戶列表單頁面(前后端分離)

代碼:

<?xml version='1.0' encoding='UTF-8' ?><!DOCTYPE mapperPUBLIC '-//mybatis.org//DTD Mapper 3.0//EN''http://mybatis.org/dtd/mybatis-3-mapper.dtd'><mapper namespace='com.xiao.dao.UserDAO'> <!--findAll--> <select resultType='User'>select id,name,salary,age,des from t_user; </select></mapper>

3、service層編寫

UserService 接口

package com.xiao.service;import com.xiao.entity.User;import java.util.List;public interface UserService { //查詢所有用戶方法 List<User> findAll();}

UserServiceImpl 實現類

package com.xiao.service;import com.xiao.dao.UserDAO;import com.xiao.entity.User;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Service;import org.springframework.transaction.annotation.Propagation;import org.springframework.transaction.annotation.Transactional;import java.util.List;@Service //代表這是一個業務層組件 作用:用來在spring工廠中創建一個userServiceImpl對象@Transactional //代表給類中所有的方法加入事務控制public class UserServiceImpl implements UserService{ @Autowired private UserDAO userDAO; @Override @Transactional(propagation = Propagation.SUPPORTS) //方法上聲明事務注解 public List<User> findAll() {return userDAO.findAll(); }}

4、進行test測試

Vue結合Springboot實現用戶列表單頁面(前后端分離)

BasicTest類

package com.xiao.test;import com.xiao.AdminApplication;import org.junit.runner.RunWith;import org.springframework.boot.test.context.SpringBootTest;import org.springframework.test.context.junit4.SpringRunner;@SpringBootTest(classes = AdminApplication.class) //指定入口類@RunWith(SpringRunner.class) //啟動工廠public class BasicTest {}

TestUserService類

package com.xiao.test;import com.xiao.service.UserService;import org.junit.Test;import org.springframework.beans.factory.annotation.Autowired;public class TestUserService extends BasicTest { @Autowired private UserService userService; @Test public void findAll() {userService.findAll().forEach(user -> System.out.println(user)); }}

測試成功!!!

Vue結合Springboot實現用戶列表單頁面(前后端分離)

4.2、前端代碼編寫

1、在created()函數中添加axios請求

# 生命周期鉤子:生命周期函數初始化階段1.beforeCreate vue實例自身事件生命周期初始化2.created 完成自定義data methods computed 注入和校驗 推薦3.beforeMount將el指向html編譯為模板,并沒有完成模板注入4.Mounted將編譯模板進行數據注入,并將注入完成模板形成虛擬dom替換el指向原始dom

代碼:

var app = new Vue({ el: '#app', data:{msg:'vue 生命周期',users:[], //定義一個users空數組,用來存貯所有用戶的信息 }, methods:{ }, computed:{ }, created(){ //執行 data methods computed 等完成注入和校驗//發送axios請求axios.get('http://localhost:8990/users').then(res=>{ console.log(res.data); this.users = res.data;}); //es6 箭頭函數 注意:箭頭函數內部沒有自己this 簡化 function(){} //存在自己this },});

2、測試

Vue結合Springboot實現用戶列表單頁面(前后端分離)

測試成功!!!

5、添加用戶信息5.1、后端代碼編寫

1、UserDAO接口層

//查詢所有用戶信息List<User> findAll();

2、UserDAOMapper.xml

<!--save--><insert parameterType='User' useGeneratedKeys='true' keyProperty='id'> insert into t_user values (#{id},#{name},#{salary},#{age},#{des})</insert>

使用 mysql 自增長序列,新插入一條數據時,怎么得到主鍵?

加入以下屬性即可:

useGeneratedKeys=“true” keyProperty=“id”

useGeneratedKeys 取值范圍true、false 默認值是:false。 含義:設置是否使用JDBC的getGenereatedKeys方法獲取主鍵并賦值到keyProperty設置的領域模型屬性中。

keyProperty 取id的key值,主要是在主鍵是自增的情況下,添加成功后可以直接使用主鍵值,其中keyProperty的值是對象的屬性值,不是數據庫表中的字段名。

3、service層編寫

UserService類

//保存用戶信息void save(User user);

UserServiceImpl類

@Overridepublic void save(User user) { userDAO.save(user);}

4、UserController控制類

//添加員工信息接口@PostMapping('saveOrUpdate')public void saveOrUpdate(@RequestBody User user){ System.out.println(user); userService.save(user);}5.2、前端代碼編寫

1、form表單中添加v-model雙向綁定

</div><div class='form-group'> <label for='name'>姓名</label> <input type='text' v-model='user.name' placeholder='請輸入姓名'></div><div class='form-group'> <label for='salary'>工資</label> <input type='text' v-model='user.salary' placeholder='請輸入工資'></div><div class='form-group'> <label for='age'>年齡</label> <input type='text' v-model='user.age' placeholder='請輸入年齡'></div><div class='form-group'> <label for='description'>個人簡介</label> <input type='text' v-model='user.des' placeholder='請輸入個人簡介'></div><button type='button' @click='saveOrUpdate'>提交</button>

2、給提交按鈕綁定 saveOrUpdate方法

var app = new Vue({el: '#app',data:{ msg:'vue 生命周期', users:[], //定義一個users空數組,用來存貯所有用戶的信息 user:{}, //定義了一個空的json對象},methods:{ saveOrUpdate(){ //保存或者修改方法//發送添加的請求console.log(this.user);axios.post('http://localhost:8990/saveOrUpdate',this.user).then(res=>{ this.user={}; //添加成功,清空數據 alert(’用戶信息更新成功!’); //更新原始列表的數據 this.findAll(); //調用查詢所有}).catch(err=>{ alert(’用戶信息更新失敗!’)}); }, findAll(){//發送axios請求axios.get('http://localhost:8990/users').then(res=>{ console.log(res.data); this.users = res.data;}); //es6 箭頭函數 注意:箭頭函數內部沒有自己this 簡化 function(){} //存在自己this }},

3、測試一下

Vue結合Springboot實現用戶列表單頁面(前后端分離)

測試成功!!!

6、修改用戶信息6.1、后端代碼

1、UserDAO類

//更新用戶信息void update(User user);//基于id查詢用戶信息User findById(Integer id);

2、UserDAOMapper.xml

<!--update--><update parameterType='User'> update t_user set name = #{name}, age = #{age}, salary = #{salary}, des = #{des} where id = #{id}</update><!--findById--><select parameterType='Integer' resultType='User'> select id,name,age,salary,des from t_user where id = #{id}</select>

3、service層

UserService類

//修改用戶信息void update(User user);//基于id查詢用戶信息User findById(Integer id);

UserServiceImpl實現類

@Overridepublic void update(User user) { userDAO.update(user);}@Override@Transactional(propagation = Propagation.SUPPORTS) //方法上聲明事務注解 Propagation:事務傳播屬性 支持事務public User findById(Integer id) { return userDAO.findById(id);}

4、control層

在這里我們要根據前端請求的參數進行判斷。如果前端請求的參數中id為空,說明是添加操作,否則是更新操作,我們執行相對應的代碼。

//添加員工信息接口@PostMapping('saveOrUpdate')public void saveOrUpdate(@RequestBody User user){ log.info('接收的業務邏輯:{}',user); //判斷是否存在id //存在: 更新操作 不存在id: 添加操作 if(StringUtils.isEmpty(user.getId())){ //如果為空log.info('添加業務邏輯......');userService.save(user); //添加 }else{log.info('更新業務邏輯......');userService.update(user); }}6.2、前端代碼

我們點擊修改按鈕,顯示用戶信息。

1、我們先給修改按鈕添加根據id查詢用戶信息事件

<a href='http://www.piao2010.com/bcjs/10029.html' class=' rel='external nofollow' rel='external nofollow' rel='external nofollow' rel='external nofollow' btn btn-info btn-sm' @click.prevent='userEditDetail(user.id)'>修改</a>

2、userEditDetail(id)

userEditDetail(id){ //用來在表單中將當前點擊用戶信息進行回顯 axios.get('http://localhost:8990/user/'+id).then(res=>{this.user = res.data; //完成數據回顯 });},

3、給提交按鈕綁定修改或者添加用戶信息事件

<button type='button' @click='saveOrUpdate'>提交</button>

4、saveOrUpdate()

saveOrUpdate(){ //保存或者修改方法 if(!this.user.name){alert('姓名不能為空!');return ; } console.log(this.user); axios.post('http://localhost:8990/saveOrUpdate',this.user).then(res=>{this.user={}; //添加成功,清空數據alert(’用戶信息更新成功!’);//更新原始列表的數據this.findAll(); //調用查詢所有 }).catch(err=>{alert(’用戶信息更新失敗!’) });},},findAll(){ //發送axios請求 axios.get('http://localhost:8990/users').then(res=>{console.log(res.data);this.users = res.data; }); //es6 箭頭函數 注意:箭頭函數內部沒有自己this 簡化 function(){} //存在自己this},

5、測試一下

Vue結合Springboot實現用戶列表單頁面(前后端分離)

測試成功!!!

7、刪除用戶信息7.1、后端代碼

1、UserDAO接口

//基于id刪除用戶信息void delete(Integer id);

2、UserDAOMapper.xml

<!--delete--><delete parameterType='Integer'> delete from t_user where id = #{id}</delete>

3、service層

UserService類

//根據id刪除用戶信息void delete(Integer id);

UserServiceImpl類

@Overridepublic void delete(Integer id) { userDAO.delete(id);}

4、controller類

//根據id刪除用戶信息的接口@DeleteMapping('delete/{id}')public void delete(@PathVariable Integer id){ userService.delete(id);}7.2、前端代碼

1、給刪除按鈕綁定刪除事件

<a href='javascript:;' rel='external nofollow' @click='delUser(user.id)'>刪除</a>

2、delUser(id)刪除用戶方法

delUser(id){ //刪除用戶方法 //友情提醒刪除 if(window.confirm('您確定要刪除這條記錄嗎?')){axios.delete('http://localhost:8990/delete/'+id).then(res=>{ alert('用戶信息刪除成功!'); this.findAll(); 調用查詢所有}).catch(err=>{ alert('用戶信息刪除失敗!');}); }}

3、測試一下

Vue結合Springboot實現用戶列表單頁面(前后端分離)

刪除信息成功!!!

到此這篇關于Vue結合Springboot實現用戶列表單頁面(前后端分離)的文章就介紹到這了,更多相關Vue結合Springboot用戶列表內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美一级免费大片| 欧美三级特黄| 黄色成人在线网址| 26uuu精品一区二区在线观看| 激情都市一区二区| 午夜在线播放视频欧美| 国产精品天干天干在线综合| 91在线码无精品| 精品国产亚洲一区二区三区在线观看| 国产寡妇亲子伦一区二区| 91精品国产91久久综合桃花| 国产一区二区日韩精品| 欧美男女性生活在线直播观看| 日本免费在线视频不卡一不卡二| 翔田千里一区二区| 亚洲一二三区在线观看| 日韩亚洲精品在线| 一区二区三区四区激情| 国产日产高清欧美一区二区三区| 亚洲黄色在线视频| 99在线精品免费视频九九视| 国产精品女人毛片| 国内精品久久久久久久97牛牛| 国产精品看片你懂得| 欧美日本一区二区高清播放视频| 久久久电影一区二区三区| 91丨九色丨尤物| 国产女人aaa级久久久级| 欧美日韩一区在线观看视频| 国产精品日韩成人| 在线看片一区| 一区二区三区av电影| 久久精品二区| 麻豆精品一区二区| 91精品免费观看| 成人影视亚洲图片在线| 欧美精品一区二区在线观看| 91啪亚洲精品| 亚洲欧洲成人精品av97| 在线视频欧美一区| 五月婷婷欧美视频| 欧美精品色综合| 成人福利电影精品一区二区在线观看 | 国产福利一区二区三区视频在线| 日韩精品在线一区二区| 欧美暴力喷水在线| 一区二区三区在线视频免费| 久久久精品性| 国产真实乱子伦精品视频| 日韩精品中文字幕一区二区三区| 色综合天天综合| 亚洲精品国产a久久久久久| 玖玖国产精品视频| 国产激情精品久久久第一区二区| 久久久国产综合精品女国产盗摄| 欧美日韩在线不卡一区| 亚洲亚洲精品在线观看| 欧美区在线观看| 色综合视频一区二区三区高清| 国产精品久久久久7777按摩| 亚洲欧美日韩国产一区二区| 韩国精品久久久| 久久精品视频在线免费观看| 国产亚洲二区| 精品中文字幕一区二区小辣椒| 欧美一卡二卡三卡| 欧美三级网页| 五月天欧美精品| 日韩一级成人av| 一区二区在线视频观看| 日韩精品乱码av一区二区| 日韩精品综合一本久道在线视频| 国产精品v日韩精品v欧美精品网站 | 亚洲综合不卡| 精品伊人久久久久7777人| 久久亚洲捆绑美女| 国产一区二区你懂的| 国产精品66部| 一区二区三区久久久| 欧美一级日韩免费不卡| 亚洲高清久久| 国产米奇在线777精品观看| 国产精品视频你懂的| 91成人在线观看喷潮| 91美女在线视频| 天天影视色香欲综合网老头| 日韩精品一区二区三区在线观看 | 日韩女优视频免费观看| 国外精品视频| 久久成人综合网| 国产精品久久综合| 欧美日韩视频在线第一区| 亚洲一级黄色| 国产伦精品一区二区三区视频青涩 | 26uuu国产电影一区二区| 亚洲欧美日韩一区在线观看| 成人av电影免费观看| 亚洲r级在线视频| 欧美xingq一区二区| 亚洲自啪免费| 欧美福利一区| 精东粉嫩av免费一区二区三区 | 狠狠色丁香久久婷婷综| 亚洲桃色在线一区| 91麻豆精品国产| 久久大逼视频| 欧美日本不卡高清| 韩国视频一区二区| 一区二区三区加勒比av| 精品国产一区二区精华| 一本一道久久a久久精品| 欧美日本三区| 国产成人综合亚洲网站| 亚洲成年人网站在线观看| 久久久精品日韩欧美| 欧美日韩一区二区三区在线 | 亚洲精品一区二区三区福利 | 日韩av电影一区| 国产精品夫妻自拍| 欧美一级二级三级乱码| 久久久久国产一区二区| 欧美日韩mv| 成人不卡免费av| 蜜臀av一区二区在线观看| 亚洲精品免费一二三区| 久久午夜老司机| 欧美另类z0zxhd电影| 国产视频一区三区| 欧美日本久久| 99精品视频在线观看| 国内偷窥港台综合视频在线播放| 一二三区精品视频| 日本一区二区三区在线不卡| 欧美一区二区三区影视| 色一情一乱一乱一91av| 国产精品呻吟| 韩国精品一区二区三区| 成人av网址在线| 国产资源在线一区| 日本视频一区二区三区| 一区二区不卡在线视频 午夜欧美不卡在| 久久久久成人黄色影片| 日韩一区二区在线观看视频播放| 欧美视频一区二区在线观看| 久久精品1区| 国产精品亚洲综合久久| 欧美视频网站| 欧美jizzhd精品欧美巨大免费| 岛国一区二区在线观看| 国产一区在线看| 看电视剧不卡顿的网站| 日本不卡视频在线| 五月开心婷婷久久| 亚洲一区二区三区爽爽爽爽爽| 国产精品国产自产拍在线| 欧美精品一区男女天堂| 日韩午夜精品电影| 制服视频三区第一页精品| 欧美日韩激情一区二区三区| 在线视频一区二区三| 色综合久久88色综合天天免费| 香蕉国产精品偷在线观看不卡| 在线亚洲自拍| 亚洲美女一区| 日韩视频在线播放| 国产区二精品视| 在线亚洲伦理| 免费久久99精品国产自| 欧美中文字幕| 久久激情一区| 色94色欧美sute亚洲线路一久| 久久精品中文字幕一区二区三区| 国产精品久久波多野结衣| 一区二区三区国产盗摄| 国产欧美精品久久| 国产精品日本欧美一区二区三区| 91久久久一线二线三线品牌| 在线观看视频免费一区二区三区| 狠狠色综合网站久久久久久久| 精品成人一区| 国产精品女主播一区二区三区| 国产精品综合色区在线观看| 久久一区二区精品| 91久久人澡人人添人人爽欧美| 欧美日韩一区二区在线观看视频 | 在线精品视频免费播放| 欧洲色大大久久| 欧美日韩一区二区在线观看视频| 在线电影院国产精品| 日韩亚洲欧美成人一区| 久久久久久久久久久久久女国产乱 | 国产女同性恋一区二区| 国产精品国产三级国产三级人妇| 综合激情网...| 亚洲在线视频网站| 三级一区在线视频先锋| 久久激情综合网| 成人午夜在线视频| 欧美韩国一区| 一区二区三区精品视频在线观看 |