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

【博文推薦】ASP.NET MVC4+BootStrap實戰(zhàn)

開發(fā) 后端
好久沒有寫關(guān)于web開發(fā)的文章了,進到這個公司一直就是winform和Silverlight,實在是沒有實戰(zhàn)web項目的機會。大D也辭職了,去搞web app了。自己也該閑暇時間多學習學習,每天進步一點點。

本博文出自51CTO博客BruceAndLee博主,有任何問題請進入博主頁面互動討論!

博文地址:http://leelei.blog.51cto.com/856755/1587301

OK,不多說了,看一下Solution的截圖

ASP.NET MVC4+BootStrap實戰(zhàn)

基本上一看就明白了,控制器調(diào)用Biz層,Biz層調(diào)用DAL層,DAL層進行數(shù)據(jù)的CURD。Utility是一些公用的類庫。ok,為什么程序集的命名都是以Bruce開頭呢,因為我在公司的英文名叫這個。廢話不多說,我們先看一下頁面

ASP.NET MVC4+BootStrap實戰(zhàn)

 

我們引入了BootStrap,主要是為了頁面布局。在Views中Partial下面放的都是部分頁。

我們先看一下運行效果,今天主要是講頁面初始化部分。

ASP.NET MVC4+BootStrap 實戰(zhàn)

其實查詢條件就是婚否,出生日期,姓名的模糊查詢。我們先看一下頁面Index.cshtml的代碼

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.     <meta charset="utf-8" /> 
  5.     <meta http-equiv="X-UA-Compatible" content="IE=edge" /> 
  6.     <meta name="viewport" content="width=device-width;initial-scale=1" /> 
  7.     <title>Compare data between Solr and DB</title> 
  8.     <link rel="stylesheet" type="text/css" href="~/BootStrap/css/bootstrap-theme.css" /> 
  9.     <link rel="stylesheet" type="text/css" href="~/BootStrap/css/bootstrap.css" /> 
  10.           @*@Styles.Render("~/css")*@ 
  11.           @Scripts.Render("~/bundles/BootStrap"
  12.           @Scripts.Render("~/bundles/Scripts"
  13.     <style type="text/css"
  14.         .pre-Scrollable { 
  15.             max-height: 700px; 
  16.             overflow-y: scroll; 
  17.         } 
  18.     </style> 
  19. </head> 
  20. <body> 
  21.     <div class="container"
  22.         <form id="formsync"
  23.             <div class="row"
  24.                 <div class="col-md-12"
  25.                     <h1 style="color:red"><b>Compare Data Between Solr and DB</b></h1> 
  26.                 </div> 
  27.             </div> 
  28.             <div class="row" id="divloding" style="display:none;text-align:center"
  29.                 <div class="col-md-6"
  30.                     <img src="~/Images/ajaxLoading.gif" alt="load failed" /> 
  31.                     <label>getting,please wait......</label> 
  32.                 </div> 
  33.             </div> 
  34.             <div class="row" id="divcompare" style="display:none;text-align:center"
  35.                 <div class="col-md-6"
  36.                     <img src="~/Images/ajaxLoading.gif" alt="load failed" /> 
  37.                     <label>comparing,please wait......</label> 
  38.                 </div> 
  39.             </div> 
  40.             <div class="row" id="divfix" style="display:none;text-align:center"
  41.                 <div class="col-md-6"
  42.                     <img src="~/Images/ajaxLoading.gif" alt="load failed" /> 
  43.                     <label>fixing,please wait......</label> 
  44.                 </div> 
  45.             </div> 
  46.             <div class="row" style="margin-top:10px"
  47.                 <div class="col-md-12 form-inline"
  48.                     <div class="form-group input-group"
  49.                         <span class="input-group-addon">IsMarried:</span> 
  50.                         @Html.DropDownList("ddlMarried", ViewBag.MarriedList as SelectList, nullnew { id = "ddlMarried"@class = "form-control" }) 
  51.                     </div> 
  52.                     <div class="form-group" style="margin-left:10px"
  53.                         <label class="control-label">BirthDay:</label> 
  54.                         <input type="date" id="txtdatestart" class="form-control"
  55.                         <label class="control-label">-</label> 
  56.                         <input type="date" id="txtdateend" class="form-control"
  57.                     </div> 
  58.                     <div class="form-group input-group" style="margin-left:10px"
  59.                         <span class="input-group-addon">Name:</span> 
  60.                         <input id="txtusername" type="text" class="form-control" placeholder="input name..." style="width:120px" /> 
  61.                     </div> 
  62.                     <div class="form-group" style="margin-left:10px"
  63.                         <input id="btnsearch" type="button" class="btn btn-info" value="Get" style="width:70px" /> 
  64.                     </div> 
  65.                 </div> 
  66.             </div> 
  67.             <div class="row" style="margin-top:10px"
  68.                 <div id="divresult" class="col-md-7 form-inline  pre-Scrollable"
  69.                     @{Html.RenderPartial("~/Views/Partial/UserInfoPartial.cshtml");} 
  70.                 </div> 
  71.                 <div class="col-md-5"
  72.                     @{Html.RenderPartial("~/Views/Partial/DiffAndSameWithSolrPartial.cshtml");} 
  73.                 </div> 
  74.             </div> 
  75.         </form> 
  76.     </div> 
  77. </body> 
  78. </html> 

我們使用html5+BootStrap布局,這里用到了BootStrap的網(wǎng)格系統(tǒng),將瀏覽器平分為12份,即12列,很容易構(gòu)造出響應式布局系統(tǒng)。那么什么是BootStrap的網(wǎng)格系統(tǒng),看如下的解釋

ASP.NET MVC4+BootStrap實戰(zhàn)

 OK,我們怎么看是否是響應式的布局呢,我們打開谷歌瀏覽器,現(xiàn)將瀏覽器縮小到一定程度。

ASP.NET MVC4+BootStrap實戰(zhàn)

看到了吧,即使設備瀏覽器這么小,我們還是能用。那我們在手機模擬器中測試一下,打開谷歌瀏覽器,按F12,點擊手機模擬器樣的東西,然后Device選擇iphone6。 

ASP.NET MVC4+BootStrap實戰(zhàn)

我們看到iphone6下面的效果是這樣的。說到這里我最近很討厭兩個廣告,一個是“這個是iphone6,這個是iphone6 plus,它們都有一個叫健康的東西.....但是好吃啊”,還有一個是“當牛魔王變成一個餃子,我愿意變成一雙筷子”。看到這兩個廣告,我想砸電視。

那為什么不同的設備不同的瀏覽器都是可以正常瀏覽的呢,原因就在于這段代碼

  1. <meta name="viewport" content="width=device-width;initial-scale=1" /> 

這段代碼的意思是網(wǎng)頁寬度默認等于屏幕寬度,縮放比例默認為1(網(wǎng)頁初始比例占屏幕的100%)。

ok,我們接下來看head部分css和js的引用,這里有個新東西叫Bundle,用來打包壓縮js或者css的。通過它打包壓縮的js或者css客戶端只需要下載一次包即可,而且可以在客戶端緩存起來,當檢測到有更新時,才會重新下載。

下面是Bundle.cs的代碼

  1. using System.Web; 
  2. using System.Web.Optimization; 
  3.   
  4. namespace Brue.GRLC.Web 
  5.     public class BundleConfig 
  6.     { 
  7.         // 有關(guān) Bundling 的詳細信息,請訪問 http://go.microsoft.com/fwlink/?LinkId=254725 
  8.         public static void RegisterBundles(BundleCollection bundles) 
  9.         { 
  10.             bundles.Add(new ScriptBundle("~/bundles/BootStrap").Include( 
  11.                         "~/Scripts/jquery-1.11.1.js","~/BootStrap/js/bootstrap.js")); 
  12.   
  13.             bundles.Add(new ScriptBundle("~/bundles/Scripts").Include("~/Js/Index.js")); 
  14.   
  15.             bundles.Add(new StyleBundle("~/css").Include("~/BootStrap/css/bootstrap-theme.css" 
  16.                 , "~/BootStrap/css/bootstrap.css")); 
  17.         } 
  18.     } 

注意,在這里引用js的時候不要引用壓縮過的js,比如xxx.min.js。當Bundle在遇到這種js命名文件的時候,直接就忽略掉了。那么我們在Head中只需要使用如下代碼來引用即可。

  1. @Scripts.Render("~/bundles/BootStrap"
  2. @Scripts.Render("~/bundles/Scripts"

OK,在這我碰到一個問題,就是我的css通過這種方式引用,始終提示Index out of range。如果哪位大牛知道原因的話麻煩留個言,謝謝!

 

OK,我們接下來看一下控制器代碼,頁面剛進來,會走Home/Index。

  1. public ActionResult Index() 
  2.         { 
  3.             List<object> marriedList = GRLCBiz.GetInstance().GetMarriedList(); 
  4.             SelectList selectList = new SelectList(marriedList, "MarriedID""DisplayContent""-1"); 
  5.             ViewBag.MarriedList = selectList; 
  6.   
  7.             DataResponse<UserDBEntity> dataResponse = GRLCBiz.GetInstance().GetUserInfoEntityList(); 
  8.             UserInfoViewModel userInfoViewModel = new UserInfoViewModel(); 
  9.             userInfoViewModel.DataResponse = dataResponse; 
  10.             userInfoViewModel.DataResponse.PageIndex = ConstValues.CONN_DefaultPageIndex; 
  11.             userInfoViewModel.DataResponse.PageSize = ConstValues.CONN_DefaultPageSize; 
  12.             userInfoViewModel.DataResponse.StartPageIndex = 1
  13.             return View(userInfoViewModel); 
  14.         } 

首先我們構(gòu)造了一個SelectList用于下拉列表,Biz層的代碼很簡單

  1. public dynamic GetMarriedList() 
  2.         { 
  3.             IList<object> marriedList = new List<object>(); 
  4.             marriedList.Add(new { MarriedID = -1, DisplayContent = "No Selection" }); 
  5.             marriedList.Add(new { MarriedID = 0, DisplayContent = "Married" }); 
  6.             marriedList.Add(new { MarriedID = 1, DisplayContent = "UnMarried" }); 
  7.   
  8.             return marriedList; 
  9.         } 

用匿名類去構(gòu)造一個List。接下來就是DataReponse的獲取,Biz層的代碼如下

  1. public DataResponse<UserDBEntity> GetUserInfoEntityList(UserInfoRequest request = null
  2.         { 
  3.             if(request==null
  4.             { 
  5.                 request = new UserInfoRequest(); 
  6.                 request.PageIndex = ConstValues.CONN_DefaultPageIndex; 
  7.                 request.PageSize = ConstValues.CONN_DefaultPageSize; 
  8.             } 
  9.             
  10.             int totalCount=0
  11.   
  12.             List<UserDBEntity> userDBEntityList = GRLCDAL.GetInstance().GetUserInfoEntityList(request, out totalCount); 
  13.             DataResponse<UserDBEntity> dataResponse = new DataResponse<UserDBEntity>(); 
  14.             dataResponse.DataList = userDBEntityList; 
  15.             dataResponse.TotalCount = totalCount; 
  16.             return dataResponse; 
  17.         } 

沒什么可說的,ConstValues類中是一些靜態(tài)只讀屬性

  1. public class ConstValues 
  2.     { 
  3.         public static readonly string CON_DBConnection = ConfigurationManager.ConnectionStrings["DB_ConnectionStr"].ToString(); 
  4.         public static readonly string CON_DbScriptXmlFolder = ConfigurationManager.AppSettings["DbScriptXmlFolder"]; 
  5.         public static readonly int CONN_DefaultPageSize = int.Parse(ConfigurationManager.AppSettings["DefaultPageSize"]); 
  6.         public static readonly int CONN_DefaultPageIndex = 1
  7.         public static readonly int CONN_PagerDisplayCount = int.Parse(ConfigurationManager.AppSettings["PagerDisplayCount"]); 
  8.     } 

看一下DAL層。

  1. public List<UserDBEntity> GetUserInfoEntityList(UserInfoRequest request, out int totalCount) 
  2.         { 
  3.             totalCount = 0
  4.             string sqlScript = string.Empty; 
  5.             try 
  6.             { 
  7.                 sqlScript = DBScriptManager.GetScript(this.GetType(), "GetUserInfo"); 
  8.                 SqlParameter[] sqlParameters =  
  9.                 { 
  10.                     new SqlParameter("@IsMarried",SqlDbType.Char,1), 
  11.                     new SqlParameter("@StartDate",SqlDbType.DateTime), 
  12.                     new SqlParameter("@EndDate",SqlDbType.DateTime), 
  13.                     new SqlParameter("@UserName",SqlDbType.NVarChar,20), 
  14.                     new SqlParameter("@PageIndex",SqlDbType.Int), 
  15.                     new SqlParameter("@PageSize",SqlDbType.Int), 
  16.                     new SqlParameter("@TotalCount",SqlDbType.Int) 
  17.                 }; 
  18.   
  19.                 sqlParameters[0].Value = request.IsMarried; 
  20.                 sqlParameters[1].Value = request.StartDate; 
  21.                 sqlParameters[2].Value = request.EndDate; 
  22.                 sqlParameters[3].Value = request.UserName; 
  23.                 sqlParameters[4].Value = request.PageIndex; 
  24.                 sqlParameters[5].Value = request.PageSize; 
  25.                 sqlParameters[6].Direction = ParameterDirection.Output; 
  26.   
  27.                 DataSet ds = SqlHelper.ExecuteDataset(ConstValues.CON_DBConnection, CommandType.Text, sqlScript, sqlParameters); 
  28.                 if (ds != null && ds.Tables.Count > 0
  29.                 { 
  30.                     totalCount = Convert.ToInt32(sqlParameters[6].Value); 
  31.                     return ds.Tables[0].ToEntityList<UserDBEntity>(); 
  32.                 } 
  33.   
  34.                 return new List<UserDBEntity>(); 
  35.             } 
  36.             catch (Exception ex) 
  37.             { 
  38.                 LogHelper.WriteExceptionLog(MethodBase.GetCurrentMethod(), ex); 
  39.                 return null
  40.             } 
  41.         } 

OK,我們看一下這個GetUserInfo腳本,在Bruce.GRLC.DbScriptXml程序集下。

ASP.NET MVC4+BootStrap實戰(zhàn)

  1. <?xml version="1.0" encoding="utf-8" ?> 
  2. <Scripts> 
  3.   <Script Key="GetUserInfo"
  4.     <![CDATA[ 
  5. DECLARE @UserTempTable TABLE 
  6. (   
  7.     ID INT IDENTITY(1,1) NOT NULL, 
  8.     UserNo CHAR(25) NOT NULL 
  9.   
  10. INSERT INTO @UserTempTable 
  11.     UserNo 
  12. SELECT 
  13.     A.UseNo 
  14. FROM Bonus.dbo.[User] A WITH(NOLOCK) 
  15. LEFT JOIN Bonus.dbo.UerInfo B WITH(NOLOCK) 
  16.     ON A.UseNo = B.UseNo 
  17. WHERE (@IsMarried IS NULL OR @IsMarried = '' OR B.Temper = @IsMarried
  18.     AND 
  19.     ( 
  20.         @StartDate IS NULL  
  21.         OR @EndDate IS NULL  
  22.         OR B.BirthDay BETWEEN @StartDate AND @EndDate 
  23.     ) 
  24.     AND  
  25.     ( 
  26.         @UserName IS NULL  
  27.         OR @UserName = ''  
  28.         OR B.Name LIKE '%' + @UserName + '%' 
  29.     ) 
  30. ORDER BY A.UseNo ASC 
  31.       
  32. SELECT @TotalCount = COUNT(1) FROM @UserTempTable 
  33.   
  34. SELECT 
  35.     UseNo, 
  36.     Name, 
  37.     Age, 
  38.     Married 
  39. FROM( 
  40.     SELECT 
  41.         ID = ROW_NUMBER() OVER(ORDER BY UseNo ASC), 
  42.         A.UseNo, 
  43.         B.Name, 
  44.         B.Age, 
  45.         Married = CASE WHEN B.Temper = '1' 
  46.                         THEN '已婚' 
  47.                        ELSE '未婚' 
  48.                   END 
  49.         FROM Bonus.dbo.[User] A WITH(NOLOCK) 
  50.     LEFT JOIN Bonus.dbo.UerInfo B WITH(NOLOCK) 
  51.         ON A.UseNo = B.UseNo 
  52.     INNER JOIN @UserTempTable C 
  53.         ON C.UserNo = A.UseNo 
  54. ) N 
  55. WHERE ID BETWEEN (@PageIndex - 1)* @PageSize + 1 AND @PageIndex * @PageSize 
  56.    ]]> 
  57.   </Script> 
  58. </Scripts> 

腳本很簡單,就是傳入?yún)?shù)查分頁數(shù)據(jù)。

在DAL層我們將DataTable通過ToEntityList轉(zhuǎn)化為了實體List,在Utility中我們定義了一個擴展用來轉(zhuǎn)化。

  1. public static class DataTableToEntityExtension 
  2.     { 
  3.         public static List<T> ToEntityList<T>(this DataTable dt) where T : class,new() 
  4.         { 
  5.             List<T> entityList = new List<T>(); 
  6.   
  7.             Type entityType = typeof(T); 
  8.             PropertyInfo[] propertys = entityType.GetProperties(); 
  9.             DataMappingAttribute mappingAttribute = null
  10.   
  11.             foreach (DataRow dr in dt.Rows) 
  12.             { 
  13.                 T tEntity = new T(); 
  14.   
  15.                 foreach (PropertyInfo pi in propertys) 
  16.                 { 
  17.                     mappingAttribute = pi.GetCustomAttribute(typeof(DataMappingAttribute)) as DataMappingAttribute; 
  18.   
  19.                     if (mappingAttribute != null && dt.Columns.Contains(mappingAttribute.mappingName)) 
  20.                     {  
  21.                         if (!pi.CanWrite) continue
  22.   
  23.                         object value = dr[mappingAttribute.mappingName]; 
  24.                         if (value != DBNull.Value) 
  25.                             pi.SetValue(tEntity, value, null); 
  26.                     } 
  27.                 } 
  28.                 entityList.Add(tEntity); 
  29.             } 
  30.             return entityList; 
  31.         } 
  32.     } 

值那么轉(zhuǎn)化的時候是怎么讓DataTable的列和實體匹配起來,你可以將列別名和實體定義成一樣的,還有一種你可以使用Attribute。那我們使用后者,因為后者更靈活。

  1. [AttributeUsage(AttributeTargets.Property)] 
  2.     public class DataMappingAttribute : Attribute 
  3.     { 
  4.         public string mappingName; 
  5.         public DbType dbType; 
  6.         public DataMappingAttribute() 
  7.         { } 
  8.   
  9.         public DataMappingAttribute(string mappingName, DbType dbType) 
  10.         { 
  11.             this.mappingName = mappingName; 
  12.             this.dbType = dbType; 
  13.         } 
  14.     } 

定義好Attribute之后,我們設置其能使用的目標只能是Property。然后我們在實體類里面的屬性上加上這個Attribute。

  1. namespace Bruce.GRLC.Model.Entity 
  2.     public class UserDBEntity 
  3.     { 
  4.         [DataMapping("UseNo", DbType.AnsiString)] 
  5.         public string UserID { get; set; } 
  6.   
  7.         [DataMapping("Name", DbType.AnsiString)] 
  8.         public string UserName { get; set; } 
  9.   
  10.         [DataMapping("Age", DbType.Int32)] 
  11.         public int Age { get; set; } 
  12.   
  13.         [DataMapping("Married", DbType.String)] 
  14.         public string Married { get; set; } 
  15.     } 

在DataTableToEntityExtension這個擴展中我們得到屬性的Attribute去和DataTable的列名去匹配,反射賦值。

OK,拿到數(shù)據(jù)后,我們在控制器構(gòu)造viewModel,傳遞給界面來綁定。我們看一下部分頁UserInfoPartial.cshtml的代碼

  1. @using Bruce.GRLC.Model.ViewModel; 
  2. @model UserInfoViewModel 
  3. <table id="tabuserinfo" class="table table-bordered table-hover"
  4.     <thead> 
  5.         <tr style="background-color: #2aabd2;color:white"
  6.             <th>帳號</th> 
  7.             <th>姓名</th> 
  8.             <th>年齡</th> 
  9.             <th>婚否</th> 
  10.         </tr> 
  11.     </thead> 
  12.     <tbody> 
  13.         @if (Model != null && Model.DataResponse != null && Model.DataResponse.DataList != null
  14.         { 
  15.             foreach (var userEntity in Model.DataResponse.DataList) 
  16.             { 
  17.                 <tr> 
  18.                     <td> 
  19.                         @userEntity.UserID 
  20.                     </td> 
  21.                     <td> 
  22.                         @userEntity.UserName 
  23.                     </td> 
  24.                     <td> 
  25.                         @userEntity.Age 
  26.                     </td> 
  27.                     <td> 
  28.                         @userEntity.Married 
  29.                     </td> 
  30.                 </tr> 
  31.             } 
  32.         } 
  33.     </tbody> 
  34. </table> 
  35. <div id="divpagination"
  36.     @{Html.RenderPartial("~/Views/Partial/PaginationPartial.cshtml", Model.DataResponse);} 
  37. </div> 

其實也就是一個應用了BoootStrap樣式的表格,有邊框和鼠標經(jīng)過的樣式。關(guān)于BootStrap的樣式的使用,請參考BootStrap官網(wǎng)。代碼很簡單,就是循環(huán)遍歷,展示數(shù)據(jù)。

 

責任編輯:王雪燕 來源: 51CTO博客
相關(guān)推薦

2014-06-30 09:22:38

ASP.NETBootstrap

2009-07-22 16:34:36

使用T4ASP.NET MVC

2009-07-31 12:43:59

ASP.NET MVC

2009-07-24 13:20:44

MVC框架ASP.NET

2009-03-12 10:42:38

RoutingIgnoreRouteASP.NET

2009-07-22 10:09:59

ASP.NET MVC

2009-07-23 15:44:39

ASP.NET MVC

2009-07-23 14:31:20

ASP.NET MVC

2009-07-22 13:24:24

ASP.NET MVC

2009-07-20 10:53:59

ASP.NET MVC

2011-09-28 13:48:06

Visual Stud

2009-07-28 09:02:32

asp.net aja

2009-04-01 12:00:43

ASP.NETMVC

2009-07-22 10:13:31

異步ActionASP.NET MVC

2009-07-20 15:44:32

ASP.NET MVC

2009-07-29 09:17:12

jQuery刪除

2009-07-22 09:11:02

Action方法ASP.NET MVC

2009-07-23 11:33:18

2010-06-23 15:44:03

ASP.NET MVC

2009-07-22 13:08:55

拯救UpdatePanASP.NET MVC
點贊
收藏

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

欧美日韩国产精品一区二区亚洲| 95精品视频| 亚洲国产精品ⅴa在线观看| 国产91在线播放九色快色| 国产精品成人无码免费| 国产精品久久久久久久久久久久久久久 | 欧美激情理论| 亚洲精品国产欧美| 亚欧美在线观看| 日本色护士高潮视频在线观看 | 久久五月精品中文字幕| 久久久精品国产免费观看同学| 国产欧美va欧美va香蕉在线 | 在线视频你懂得一区| 亚洲免费视频播放| 日韩欧美电影在线观看| 久久er99热精品一区二区| 欧美精品生活片| 永久免费看mv网站入口78| 亚洲欧洲专区| 日韩欧美aaa| 日本免费黄色小视频| 国产露出视频在线观看| 国产suv精品一区二区883| 国产精品小说在线| 亚洲图片在线视频| 黄色亚洲在线| 久久精品国产久精国产一老狼| 国产ts丝袜人妖系列视频| 国产亚洲观看| 欧美日韩一区中文字幕| 欧美一区二区三区爽大粗免费| 麻豆传媒视频在线| 久久先锋影音av鲁色资源| αv一区二区三区| 亚洲天堂手机版| 天堂精品中文字幕在线| 亚州欧美日韩中文视频| 久久久久久免费观看| 99热精品久久| 在线观看欧美www| 亚洲综合网在线观看| 成人知道污网站| 日韩欧美国产wwwww| 亚洲精品成人在线播放| h1515四虎成人| 色爱区综合激月婷婷| 你懂的av在线| av资源网在线播放| 亚洲国产成人精品视频| 蜜桃视频一区二区在线观看| 日本高清中文字幕在线| 国产精品天天看| 亚洲精品影院| 3p在线观看| 国产精品久久久久久久久图文区| 久久久婷婷一区二区三区不卡| 手机在线不卡av| caoporm超碰国产精品| 国产精品乱子乱xxxx| 国内爆初菊对白视频| 大陆成人av片| 国产免费一区二区三区| 蜜桃视频污在线观看| 国产成人精品免费视频网站| 成人羞羞视频免费| 国产自产一区二区| 99视频精品全部免费在线| 国内精品久久久久久久果冻传媒| 日本黄色一区二区三区| 99热99精品| 自拍偷拍免费精品| 国产精品嫩草在线观看| www.97av.com| www.欧美精品一二区| 精品乱码一区二区三区| 欧美日本韩国一区二区| 国产精品天天看| 麻豆一区二区三区在线观看| 牛牛电影国产一区二区| 亚洲福利国产精品| 国产精品宾馆在线精品酒店| 成人美女视频| 欧美三区在线观看| 亚欧精品在线视频| 久久久久97| 一区二区亚洲欧洲国产日韩| 亚洲伦理一区二区三区| 在线观看的日韩av| 国产成人精品一区| 国产精品久久久久久免费免熟| 国产乱子伦视频一区二区三区 | 欧美日韩123| 日韩中文视频免费在线观看| 久久久精品人妻一区二区三区四 | 国产自产一区二区| 国产亚洲欧美一级| 久久久无码中文字幕久...| 黄色污网站在线观看| 欧美亚一区二区| 性生交大片免费看l| 美女网站一区| 欧美成人免费在线视频| 91精品国产综合久久久蜜臀九色| 久久精品国产精品亚洲红杏| 亚洲伊人一本大道中文字幕| 免费动漫网站在线观看| 亚洲女子a中天字幕| 欧美日韩第二页| 粉嫩一区二区三区在线观看| 亚洲精品一区二区网址| 卡通动漫亚洲综合| 久久国产日本精品| 成人动漫视频在线观看免费| 好男人免费精品视频| 亚洲国产精品久久艾草纯爱| 日本高清久久久| 日韩精品免费一区二区三区竹菊| 日韩中文字幕在线免费观看| 在线精品免费视| 国产成人在线网站| 亚洲欧美久久234| 妞干网免费在线视频| 日韩午夜小视频| 日韩精品久久久久久久的张开腿让| 亚洲麻豆一区| 91蜜桃网站免费观看| 91网在线播放| 色婷婷久久久亚洲一区二区三区| 中文字幕1区2区| 国产精品久久久久久| 国产成人精品久久久| 五月天丁香视频| 亚洲一区二区免费视频| 手机av在线网站| 色狮一区二区三区四区视频| 人人澡人人澡人人看欧美| 色一情一乱一乱一区91av| 伊人一区二区三区| 色婷婷一区二区三区av免费看| 伊人春色之综合网| 98视频在线噜噜噜国产| 狠狠躁夜夜躁av无码中文幕| 亚洲自拍偷拍图区| 九色91porny| 在线国产一区| 91香蕉亚洲精品| 麻豆av在线导航| 3d动漫精品啪啪1区2区免费| 久久久久久久麻豆| 激情综合色播五月| 在线播放 亚洲| 欧洲午夜精品| 久久艳片www.17c.com| 国产又黄又大又粗的视频| 国产精品久久久久三级| 三上悠亚av一区二区三区| 凹凸成人精品亚洲精品密奴| 国产精品极品尤物在线观看| 国产69精品久久app免费版| 色综合夜色一区| 精品国产成人亚洲午夜福利| 日韩专区欧美专区| 午夜精品一区二区三区在线观看| av激情成人网| www.欧美精品一二三区| 99国产揄拍国产精品| 亚洲免费观看在线观看| 亚洲精品久久一区二区三区777| 极品中文字幕一区| 精品国产乱码一区二区三区四区| free性m.freesex欧美| 亚洲精品视频播放| 中文字幕日韩第一页| 最新日韩在线视频| 折磨小男生性器羞耻的故事| 亚洲精品免费观看| 欧美日韩一区二区三| 精品国产黄a∨片高清在线| 欧美成人国产va精品日本一级| 丰满少妇被猛烈进入| 色欧美乱欧美15图片| 中文字幕求饶的少妇| 国产福利一区二区三区视频| 国产成人无码精品久久久性色| 国产99久久| 成人免费高清完整版在线观看| 欧美巨大xxxx做受沙滩| 亚洲老头同性xxxxx| 中文字幕人妻一区二区在线视频 | 日本男女交配视频| 日韩影视高清在线观看| 国产精品专区一| 国产蜜臀在线| 在线播放日韩av| www.xxx国产| 日韩欧美国产视频| 一起操在线播放| 久久综合久久综合久久| 久久精品国产露脸对白| 国产欧美在线| 三级网在线观看| 九九久久电影| 99精品国产一区二区| 日韩精品第一| 91成人在线播放| av网址在线免费观看| 日韩精品视频观看| 99热精品在线播放| 在线观看视频91| 日韩字幕在线观看| 亚洲色大成网站www久久九九| 国产福利在线观看视频| 国产一区二区三区高清播放| 日韩精品视频一区二区在线观看| 五月激情综合| 日韩中文字幕一区二区| 麻豆一区二区| 99电影在线观看| 成人影院在线免费观看| 欧美在线视频导航| a级大胆欧美人体大胆666| 精品国产欧美成人夜夜嗨| 久青青在线观看视频国产| 精品国产免费一区二区三区四区| 97精品人妻一区二区三区在线 | 国产精品无码一本二本三本色| 欧美韩日精品| 日韩人妻精品一区二区三区| 区一区二视频| 日韩女优中文字幕| 亚洲国产网址| 精品日韩电影| 国产主播性色av福利精品一区| 亚洲xxx大片| 精品欧美视频| 91久久嫩草影院一区二区| yy6080久久伦理一区二区| 日本国产精品视频| 在线观看的黄色| 2018国产精品视频| 99riav视频在线观看| 欧美激情视频网站| 欧美xxxx做受欧美88bbw| 欧美成人午夜激情| 国产福利视频在线观看| 日韩视频在线一区| 欧美女优在线| 亚洲毛片一区二区| 日本高清视频免费看| 欧美一区二区三区小说| 中文字幕精品一区二| 精品国产乱码久久久久酒店| 久久精品欧美一区二区| 夜夜嗨av一区二区三区四季av| 五月综合色婷婷| 亚洲精选在线视频| 欧美国产日韩在线观看成人| 日韩理论片在线| 校园春色 亚洲| 亚洲综合男人的天堂| 麻豆一区产品精品蜜桃的特点| 亚洲综合激情小说| www.av视频在线观看| 亚洲成年人影院| 天天干天天干天天| 色妞www精品视频| 欧美性受xxx黑人xyx性爽| 欧美日韩不卡一区二区| 国产一区二区波多野结衣| 欧美一级日韩免费不卡| 黄色片一区二区三区| 亚洲第一黄色网| 五月婷婷久久久| 亚洲国产精品女人久久久| 亚洲av成人无码久久精品老人| 亚洲欧美精品伊人久久| 国产女主播在线直播| 久久精品国产久精国产一老狼| 国产传媒在线播放| 久久久久久久久久久av| 波多视频一区| 国产美女精品免费电影| 精品一区二区三区中文字幕在线| 国产伦精品一区二区三区四区视频| 秋霞蜜臀av久久电影网免费| 日韩精品久久久| 欧美激情麻豆| 18禁免费观看网站| 日韩av在线发布| 无套白嫩进入乌克兰美女| 99v久久综合狠狠综合久久| 黄色网址在线视频| 国产精品久久一卡二卡| 国产在线欧美在线| 精品久久久久久亚洲精品 | 欧美日韩精品一区视频| 国产人妻精品一区二区三| 日韩精品视频在线播放| av午夜在线| 久久中文久久字幕| 在线高清av| 亚洲在线观看视频网站| 国内露脸中年夫妇交换精品| 一区二区不卡在线观看| 亚洲精品色图| 日韩欧美理论片| 91丝袜美腿高跟国产极品老师 | 欧美一级黄色网| 欧美韩国日本| 日韩欧美手机在线| 欧美三级黄美女| 浓精h攵女乱爱av| 99re视频这里只有精品| 美女视频久久久| 欧美视频不卡中文| 亚洲成a人片77777精品| 在线不卡国产精品| 国产h片在线观看| 亚洲一区二区三区四区视频 | 麻豆av一区二区| 黄色成人在线网站| 日本中文字幕精品—区二区| 国产成人a级片| 亚洲熟女少妇一区二区| 精品欧美国产一区二区三区| 国产999久久久| 中文字幕在线看视频国产欧美在线看完整 | 国产精品对白刺激久久久| 久久久久久久久久久9不雅视频| a√天堂在线观看| 国产成人aaaa| 成人免费视频国产免费观看| 欧美性高潮床叫视频| 性生交大片免费看女人按摩| 最近2019好看的中文字幕免费| 这里有精品可以观看| 亚洲伊人第一页| 97精品97| 国产又大又黄又猛| av午夜精品一区二区三区| 日韩一级片av| 91精品国产综合久久精品图片 | 妺妺窝人体色www看人体| 久久99国产精品麻豆| 人人妻人人澡人人爽人人精品| 亚洲一区二区三区不卡国产欧美| 国产毛片毛片毛片毛片| 尤物yw午夜国产精品视频明星 | 日产精品99久久久久久| 免费成人三级| 欧美国产视频一区| 成人性生交大合| 韩国一级黄色录像| 欧美日韩国产综合草草| gogogo高清在线观看免费完整版| 97视频在线看| 久久97精品| 日韩国产小视频| 成人av在线资源网| 久久久久免费看| 日韩精品一区二区三区在线播放 | 国产精品日本一区二区不卡视频| 制服诱惑一区| 国产精品一区专区| 国产稀缺精品盗摄盗拍| 91精品国产品国语在线不卡| 免费网站成人| 亚洲自拍欧美另类| 综合国产精品| 亚洲自拍偷拍精品| 欧美日韩人人澡狠狠躁视频| 日韩电影在线观看完整版| 国产成人综合一区二区三区| 欧洲激情视频| 五月婷婷之婷婷| 亚洲高清三级视频| 欧美女优在线| 国产精品视频网站| 欧美成人亚洲| 538国产视频| 欧美性三三影院| 95在线视频| 精品一区二区三区视频日产| 久久一区中文字幕| 中文字幕91视频| 亚洲成人久久久久| 国产高清不卡| 日本免费高清一区二区| 久久国产精品72免费观看| 九九视频免费观看| 日韩视频一区在线观看| 国产传媒av在线| 亚洲精品高清视频| 99久久伊人网影院| 中文字幕在线视频第一页| 久久久最新网址| 日韩影院二区| 无码人妻aⅴ一区二区三区玉蒲团| 欧美日韩亚洲系列|