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

C#與SQL連接:GridView控件操作

開發 后端
本文介紹了GridView和DataGrid的異同、GridView操作初步、GridView中的自定義列、自定義列中的數據更新等知識。

GridView和DataGrid的異同

GridView 是 DataGrid的后繼控件,在.net framework 2 中,雖然還存在DataGrid,但是GridView已經走上了歷史的前臺,取代DataGrid的趨勢已是勢不可擋。GridView和DataGrid功能相似,都是在web頁面中顯示數據源中的數據,將數據源中的一行數據,也就是一條記錄,顯示為在web頁面上輸出表格中的一行。

GridView相對于DataGrid來說,具有如下優勢,功能上更加豐富,因為提供了智能標記面板(也就是show smart tag)更加易用方便,常用的排序、分頁、更新、刪除等操作可以零代碼實現!具有PagerTemplate屬性,可以自定義用戶導航頁面,也就是說分頁的控制更加隨心所欲。GridView和DataGrid在事件模型上也多有不同之處,DataGrid控件引發的都是單個事件,而GridView控件會引發兩個事件,一個在操作前發生,一個在操作后發生,操作前的事件多位***ing事件,操作后的事件多位***ed事件,比如Sorting 事件和sorted 事件,RowDeleting和RowDeleted事件。

GridView操作初步

1、顯示數據源中的數據

從ToolBox中選取GridView控件拖到頁面上,然后點擊右鍵,選擇Show Smart Tag,在Choose Data Source中選擇 New Data Source, 出現Data Source Configuration Wizard,選擇連接字符串,可以選擇已經存放在web.config中的ConnectionString ,然后可以選擇是使用存儲過程,還是從表或視圖中選擇數據。

在這一步,左側的Where語句可以指定查詢條件,點擊Where,出現Add Where Clause ,選擇要設定條件的列,操作符是等于還是like還是其它,然后選擇Source,也就是說要限定的條件從哪里取值,可以是Control、Session、Form、Cookie、QueryStirng等,如果選擇Control,那么需要在右側,選中是那個控件,然后還可以設定默認值,設定完后系統自動生成Sql 表達式和值的表達式,此時點擊Add按鈕,完成條件的添加,Where Cluase下出現剛剛添加的條件。如果沒有點擊Add,很容易設定了條件,但是因為沒有添加到Where子句中,所以不起作用。

在這一步,左側的Order By,可以讓我們設定排序列,就是我們取出的記錄要按照什么派遜,可以設定三個列,是升序還是降序。

在這一部,左側的Advanced,可以設定Advanced Sql Generation Options,這里可以生成這個查詢的Insert、update、Delete語句,當然,前提是您選擇的字段中必須包含了主鍵。當您想在GridView中不編寫任何代碼實現對表格的編輯、刪除等操作時,就必須在配置數據源時,在這里生成Insert、Update、Delete這些語句。 GridView中編輯刪除等操作的零代碼,就是根據配置數據源時自動生成的這些語句來完成數據源的更新刪除等操作的。

在***一步,您可以測試一下您剛剛生成的查詢是否正確,***點擊完成,數據已經出現在頁面上了,按Ctrl+F5運行。

恭喜您!您已經會使用Asp.net來顯示數據庫中的數據了。

2、讓GridView可以分頁

GridView把數據顯示出來了,但是那么多條記錄羅列到一頁上是不合適的,我們應該對數據進行分頁。還記得在asp時代,分頁是多么的麻煩,需要編寫很多的代碼,而且各種分頁組件也應運而生。而在GridView中,您會發現,分頁是如此的簡單,只需要您輕點鼠標,在Show Smart Tag中,選中Enable Paging,表格的分頁操作變完成了,是不是So Easy呢。

并不是什么數據源都可以讓GridView實現自動分頁的,比如如果DataSourceMode是DataReader,就無法實現自動分頁。而且只有ObjectDataSource是界面級別的支持分頁,類似我們常用的SqlDataSource都是先提取所有的記錄,然后只顯示本頁需要顯示的記錄,然后拋棄其余的記錄,都有點浪費資源的啦!

當GridView的AllowPaging屬性設置為True的時候,我們實現了分頁,我們還可以對分頁進行一些個性化的設置。常用的屬性包括:PageIndex――設置數據顯示的當前頁面,默認是0,也就是數據的首頁。PageSize ――也就是一頁顯示多少條記錄,默認為10條。在PagerSettings中,還可以對分頁的導航按鈕進行詳細設置,在Mode屬性中,可以設置:Numeric――默認的,分頁用數字表示,1,2,3……。NextPrevious、NextPreviousFirstLast、NumericFirstLast均可顧名思義,顯示上一頁、下一頁、首頁、末頁等。當Mode設定不是Numeric時,那么可以通過設定FirstPageText、LastPageText等屬性來實現分頁導航時,到首頁、末頁、下頁、上頁時顯示的文字提示。

如果想實現分頁界面的完全自動控制,還可以點擊GridView右鍵,選擇編輯模版-PagerTemplate來實現,在模版中加入若干個Button控件,然后將Button控件的CommandName屬性設置為Page,將CommandArgument屬性分別設置為First、Last、Prev、Next或者一個數字,即可實現分頁操作。

3、GridView中的編輯、刪除、排序

數據從數據源中提取出現,顯示在網頁上后,我們如果需要對其中的數據進行編輯、更新、刪除等操作,還是不需要編寫任何代碼,利用GridView內置的功能即可實現。

在智能標記中,點擊編輯列,在Avaliable Fields中,選擇ComandField,然后雙擊Edit,update,cancel和Delete,我們就為GridView添加了編輯和刪除功能。如果在配置數據源的時候,我們已經生成了Insert、update、delete這些語句,那么我們現在就可以執行程序。點擊頁面上的Edit,出現Update和Cancel按鈕,同時當前行除了主鍵以外的列,數值都放在了一個文本框中,可以進行編輯,然后點擊Update即可保存。點擊Delete,刪除當前行記錄。您是不是已經被GridView強大的功能折服了呢?

在Show Smart Tag中,選擇Enable Sorting,這時所有列的Header都變成了一個超鏈接,其實這些都是一個LinkButton控件,運行代碼,在網頁生成的數據表中,點擊***行中的列名,即可按照當前列進行排序,再次點擊則反向排序。

如果您只需要對其中的幾列進行排序,可以在智能標記中,選擇編輯列,選中要排序的列,然后在右側的屬性中找到SortExpression屬性,然后從下拉框中選擇根據哪個字段排序,一般當然是當前字段咯,完成排序的設置。如果您不需要這一列參與排序,那么只需要把此列的SortExpression屬性后面的值刪除,也就是說設置成空字符串即可。試一試,是不是排序已經盡在掌握之中了呢?

GridView中的自定義列

GridView可以根據數據源自動生成列,但是如果我們需要自定義列的顯示方式,讓GridView的列完完全全的由我們自己來控制,我們就需要用到一種特殊的列――TemplateField。因為GridView生成的列都是一個字段一列,如果我們需要把兩個字段合并為一列顯示呢?我們可以使用模板列。我們可以指定包含標記和控件的模版,自定義列的布局和行為,我們可以新建一個模版列,也可以直接把已經生成的列轉換為模版列來進行個性化的設置。

在GridView上單擊右鍵,選擇編輯模版,在彈出菜單中選擇要編輯的列,出現列模版的編輯畫面。其中HeaderTemplate――自定義列的標頭部分顯示的內容,FooterTemplate――腳注部分顯示哪諶藎?/SPAN>ItemTemplate――是打開網頁后此列數據顯示的內容,EditItemTemplate――此列處于編輯狀態時如何顯示,AlternatingItemTemplate――交替項顯示的內容,也就是說為了顯示效果,可以隔行分別以不同的風格顯示。

Example 1:

我們現在假設有一個表,其中有一個字段是username,我們現在產生一個自定義列,自定義列中包含此人的照片,同時我們假定照片的路徑為image/username.jpg。我們首先右鍵點擊GridView,在智能標記中,選擇編輯列,添加一個模版列,然后編輯模版中的ItemTemplate,加入一個Image控件,然后右鍵點擊Image控件,選擇Edit DataBindings,在ImageUrl中設置Field Binding,首先我我要Bound to 數據源中的某列,因為所有圖片的路徑和格式是相同的,唯有名字不同而已,所以我們這里選中username字段,在format中,我們要自己定義其格式,輸入image/{0}.jpg, {0}代表的就是上面綁定的字段,下面有一個Two Way DataBinding 的復選框,就是是否雙向綁定的意思,如果單向綁定,一般采用Eval,也就是說數值只從數據源傳到頁面上,如果雙向綁定,也就是采用Bind的話,對數據的修改可以回傳到數據源之中。

在web頁面執行時,不同的行因為username不同,圖片的名字也會做出相應的替換。點擊確定,然后執行當前網頁,我們就可以看到在我們的自定義列中顯示出了用戶的照片。

Example 2:

在數據庫中,存儲性別的時候,一般采用bit數據類型,存儲為True或者False,在GridView自動生成列的時候,一般使用CheckedBoxField 列來顯示bit類型的數據,顯示在網頁上就是一個單選框,如果選中,也就是Checked了,就是男的,否則就是女的。這樣看起來,很不直觀,下面我們通過自定義列將性別顯示為男、女。

首先在GridView的Show Smart Tag中,選擇編輯列,然后雙擊TemplateFields ,添加了一個模版列,確定后,點擊右鍵選擇編輯模版,選中剛添加的列。在ItemTemplate中添加一個DropListDown控件,然后編輯它的數據綁定,Edit DataBinding,把SelectedValue屬性綁定到性別列。

在DropListDown控件中選擇 Edit Item,就是編輯其下拉列表的項,我們添加兩個Item,一個的Text屬性是男,Value設置為True,一個的Text屬性設置為女,Value屬性設置為False。到這里,你明白了么?因為DropDownList控件的顯示文本和其值是可以不一樣的,我們用數據綁定取到了性別這一列的值,True或者False,然后反映到DropDownList控件上,如果值為True,因為Text屬性為男的Item的Value為True,所以我們現在運行網頁,在新添加的列中,顯示的不再是單選框或者True、false這些沒有含義的東西,而是以下拉列表的方式顯示出了當前用戶是 男還是女。

自定義列中的數據更新

假設數據庫中有一個"權限"字段,值為0代表未審核用戶,為1代表一般用戶,為9則代表管理員用戶。根據前面所說的自定義列的辦法,通過對DropListDown的綁定,在網頁中顯示權限為 "管理員",而不是顯示數字9。問題產生了,如果我們調整用戶權限的話,比如把一般用戶更改為管理員,在編輯模版中的用戶權限的下拉列表,如何把它的值返回給數據源來完成更新操作。

我們在EditItemTemplate中設置的DropListDown控件,必須選中了Two Way DataBinding,也就是數據雙向幫定,這樣才能返回數據。前面我們談到,在GridView中,事件不是單個的,是兩個,一個是發生前,一個是發生后,因為我們需要在數據更新前把下拉列表的權限值傳送出去,所以我們需要對GridView1_RowUpdating 進行編碼,編碼如下:

  1. protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)  
  2.  
  3. {  
  4.  
  5. //當前編輯的是哪行?  
  6.  
  7.         int index = GridView1.EditIndex;  
  8.  
  9.  
  10.  
  11. //取得當前編輯行的GridViewRow對象  
  12.  
  13.         GridViewRow gvr = GridView1.Rows[index];  
  14.  
  15.  
  16.  
  17. //在當前行中,尋找DropListDown控件  
  18.  
  19.         DropDownList dp = (DropDownList)gvr.FindControl("editdrop");  
  20.  
  21.  
  22.  
  23. //將DropListDown的值賦給NewValues集合中的權限字段。  
  24.  
  25.         e.NewValues["rights"] = dp.SelectedValue;  
  26.  

RowDataBound事件

在創建gridView控件時,必須先為GridView的每一行創建一個GridViewRow對象,創建每一行時,將引發一個RowCreated事件;當行創建完畢,每一行GridViewRow就要綁定數據源中的數據,當綁定完成后,將引發RowDataBound事件。如果說我們可以利用RowCreated事件來控制每一行綁定的控件,那么我們同樣可以利用RowDataBound事件來控制每一行綁定的數據,也就是讓數據如何呈現給大家。

還舉同樣的例子,在數據表中,存在性別列,上面我們用DropListDown控件的DataBounding來表示出了中文的性別,但是畢竟不太美觀,我們現在可以利用Label控件和RowDataBound事件來實現***的中文性別顯示。RowDataBound,

首先,還是把性別列,設置為模板列,并添加一個Label控件,將Label控件綁定到數據源的性別段,然后我們在GridView控件屬性的事件列表中雙擊RowDataBound,生成如下事件:

Example:

  1. protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)  
  2.  
  3. {  
  4.  
  5. //判斷當前行是否是數據行  
  6.  
  7.         if (e.Row.RowType == DataControlRowType.DataRow)  
  8.  
  9.         {  //用FindControl方法找到模板中的Label控件  
  10.  
  11. Label lb1= (Label)e.Row.FindControl("Label1");  
  12.  
  13. //因為RowDataBound是發生在數據綁定之后,所以我們可以  
  14.  
  15. //判斷Label綁定的數據,如果是True,就更改其text屬性為男  
  16.  
  17.                 if (lb1.Text== "True")  
  18.  
  19.                       lb1.Text = "男";  
  20.  
  21.                 else 
  22.  
  23.                       lb1.Text = "female";  
  24.  
  25.         }  
  26.  
  27.     }  

RowType

RowType可以確定GridView中行的類型,RowType是玫舉變量DataControlRowType中的一個值。RowType可以取值包括 DataRow、Footer、Header、EmptyDataRow、Pager、Separator。很多時候,我們需要判斷當前是否是數據行,通過如下代碼來進行判斷 :

  1. if (e.Row.RowType == DataControlRowType.DataRow) 

RowDeleting和RowDeleted事件

RowDeleting發生在刪除數據之前,RowDeleted發生在刪除數據之后。

使用RowDeleting事件,可以在真正刪除前再次確認是否刪除,可以通過設置GridViewDeleteEventArgs.Cancel=True來取消刪除;也可以用于判斷當前數據庫記錄數,如果只剩一條記錄且數據庫不能為空則提示并取消刪除操作。

使用RowDeleted事件,可以在刪除后,通過GridViewDeletedEventArgs的Exception屬性判斷刪除過程中是否產生異常,如無異常,則可以顯示類似于” 1 Records deleted” 之類的提示信息。

Example:

   

  1.  protected void GridView1_RowDeleting(object sender, GridViewDeleteEventArgs e)  
  2.  
  3. {  
  4.  
  5. //取得當前行號,并取得當前行的GridViewRow對象  
  6.  
  7.         int index=e.RowIndex ;  
  8.  
  9.         GridViewRow gvr=GridView1.Rows[index];  
  10.  
  11. //取得當前行第二個單元格中的文字  
  12.  
  13.         str1 = gvr.Cells[1].Text;  
  14.  
  15. //進行提示  
  16.  
  17.         Message.Text  ="您將刪除一個用戶,其姓名為"+str1 ;  
  18.  
  19.     }  
  20.  
  21.     protected void GridView1_RowDeleted(object sender, GridViewDeletedEventArgs e)  
  22.  
  23. {  
  24.  
  25. //如果沒有產生異常,則提示成功刪除,否則提示刪除失敗  
  26.  
  27.         if (e.Exception == null)  
  28.  
  29.             Message.Text += "< br>您成功刪除了"+str1 ;  
  30.  
  31.         else 
  32.  
  33.             Message.Text += "刪除失敗,請聯系管理員";  
  34.  

RowEditing事件

在GridView中的行進入編輯模式之前,引發RowEditing事件,如果您需要在編輯記錄前進行某些預處理,可以在這里操作。如果想取消對當前行的編輯,可以把GridViewEditEventArgs 對象的 Cancel 屬性設置為 true即可。

Example:

   

  1.  protected void GridView1_RowEditing(object sender, GridViewEditEventArgs e)  
  2.  
  3. {  
  4.  
  5. //用NewEidIndex取得當前編輯的行號,然后獲取gridviewrow對象  
  6.  
  7.         GridViewRow gvr = GridView1.Rows[e.NewEditIndex];  
  8.  
  9.  
  10.  
  11. //判斷,如果當前編輯行姓名欄為admin用戶,則取消對當前行的編輯  
  12.  
  13.         if (gvr.Cells[1].Text =="admin")  
  14.  
  15.             e.Cancel = true;  
  16.  
  17. }  
  18.  

RowUpdating和RowUpdated事件

RowUpdating事件發生在更新數據源之前,RowUpdated發生在更新數據源之后。

我們可以在記錄更新前利用RowUpdating做一些預處理工作,比如修改密碼時,因為密碼在數據庫中不是明文存儲,進行了hash,所以在更新密碼前,應該生成其hash值,再進行更新操作。RowUpdated則可以檢驗更新是否成功。

Example:

   

  1.  protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)  
  2.  
  3.     {  
  4.  
  5.         GridViewRow gvr = GridView1.Rows[GridView1 .EditIndex  ];  
  6.  
  7. //尋找輸入密碼的控件  
  8.  
  9.         TextBox tb1 = (TextBox)gvr.FindControl("tb_password");  
  10.  
  11. //將此控件中的文本hash后,把password存入NewValues這個字典中  
  12.  
  13.         e.NewValues ["password"] =tb1.Text .GetHashCode().ToString () ;  
  14.  
  15.  
  16.  
  17.     }  
  18.  
  19.     protected void GridView1_RowUpdated(object sender, GridViewUpdatedEventArgs e)  
  20.  
  21. {  
  22.  
  23. //如無異常,則更新成功  
  24.  
  25.         if (e.Exception == null)  
  26.  
  27.             Message.Text += "更新成功!";  
  28.  
  29.     }  
  30.  

Keys、OldValues、NewValues集合

Keys字典中一般存放的是數據源中的主鍵字段的key和value的對應值,如果主鍵由多個字段組成,那么Keys為每個鍵字段添加其字段名稱和值。OldValues中存放的是要更新的行的字段名和原始值,每個字段為其中的一項。NewValues中存放的是要更新的行的字段名和修改后的值,每個字段為其中的一項。注意,主鍵字段只存放于keys集合中。

這三個集合中的每一項都是DictionaryEntry類型的對象,我們可以用DictionaryEntry.Key來確定一個項的字段名稱,用DictionaryEntry.Value來確定某項的值。

在上面的例子中,為了把密碼明文加密后再存入數據庫,我們利用了NewValues字段,重新設置key為password的項的值。為了保證安全性,我們在更新數據前對NewValues中的所有值進行html編碼:

Example1:

  1. protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)  
  2.  
  3. {  
  4.  
  5. //遍歷NewValues,取得其中每一對DictionaryEntry對象  
  6.  
  7.        foreach (DictionaryEntry de in e.NewValues)  
  8.  
  9.  
  10.  
  11. //de.key就是字段名,如果此處單獨更新某字段的話,也可以直接填寫字段名,//比如 e.NewValues[“password”]  
  12.  
  13.  
  14.  
  15.        e.NewValues[de.Key] = Server.HtmlEncode(de.Value.ToString());  
  16.  
  17.     }  
  18.  

Example2:

  1.     protected void GridView1_RowUpdating(object sender, GridViewUpdateEventArgs e)  
  2.  
  3. {  
  4.  
  5. //分別利用Keys、OldValues、NewValues取得主鍵名、原始數據和更新后數據  
  6.  
  7.         Message .Text  = e.Keys["username"] + "的email地址從" + e.OldValues["email"] + "變更為" + e.NewValues["email"];  
  8.  
  9. }   

GridView控件操作方面的知識就介紹到這里。

【編輯推薦】

  1. C# Thread類的應用
  2. C#線程:BeginInvoke和EndInvoke方法
  3. 學習C#:Attribute與Property
  4. C#編碼標準66條
  5. C#委托事件及自定義事件的處理
責任編輯:book05 來源: cnblogs
相關推薦

2009-09-08 17:37:54

C# listbox控

2009-09-16 10:56:22

C#開發ActiveX

2009-08-24 15:41:50

C#連接SQL Ser

2009-08-18 14:36:36

C# 操作Excel

2011-05-20 16:07:29

C#

2009-08-27 13:55:08

C#子線程

2009-07-30 16:56:14

C#時間控件

2009-08-24 11:23:41

C# TimeLabe

2009-08-19 11:21:02

C# ListBox控

2009-08-11 14:45:41

C# DataGrid

2009-08-18 17:41:22

C# ListView

2009-08-03 14:17:18

C#連接AccessC#連接SQL Ser

2009-08-21 15:27:11

C# DataGrid

2009-09-04 17:58:38

C# Web Brow

2009-08-12 10:35:50

C#調用ActiveX

2009-08-21 17:55:52

C#復合控件

2009-08-06 16:58:40

C#編寫ActiveX

2009-08-19 15:30:40

C#復合控件構建

2009-08-28 15:05:35

C#編寫Calenda

2009-08-14 14:19:50

Enhanced LiC#構建
點贊
收藏

51CTO技術棧公眾號

欧美极品欧美精品欧美视频| 久久精品动漫| 欧美午夜女人视频在线| 92裸体在线视频网站| 手机在线免费看毛片| 精品国产亚洲一区二区三区大结局| 亚洲欧洲av在线| 91色p视频在线| 久久综合色综合| 一区二区美女| 欧美精品三级在线观看| 日韩中文在线字幕| 少妇人妻一区二区| 日韩精品视频网| 欧美成年人网站| 日韩av一二区| 99精品美女视频在线观看热舞| √…a在线天堂一区| 国产在线精品一区二区三区》 | 日韩免费电影一区| 超级碰在线观看| 日本大臀精品| 日韩成人dvd| 欧美疯狂性受xxxxx另类| 欧美做受高潮中文字幕| 欧美123区| 亚洲精品成a人| 欧美极品jizzhd欧美| 一级全黄裸体免费视频| 亚洲精品人人| 久久精品国产一区二区三区 | 99国内精品久久久久| 五月天激情综合| 色综合视频二区偷拍在线| 一区二区三区黄色片| 综合精品一区| 在线观看国产成人av片| 欧洲成人午夜精品无码区久久| av网站导航在线观看免费| 91麻豆高清视频| 成人午夜激情网| 欧美成人一区二区三区四区| 欧美电影免费| 亚洲精品99久久久久| 杨幂毛片午夜性生毛片 | 亚洲品质自拍视频网站| 欧洲一区二区在线| 色噜噜一区二区三区| 国产乱子伦视频一区二区三区 | 婷婷视频在线| 国产99久久久国产精品免费看| 热久久这里只有| 国产一级生活片| 日韩免费视频| 欧美精品一区二区三| 欧美精品色视频| av成人在线播放| 欧美性极品xxxx做受| 每日在线观看av| 久久电影网站| 亚洲综合色噜噜狠狠| 一本一本久久a久久精品综合妖精| 欧洲一区av| 成人亚洲一区二区一| 91九色单男在线观看| 中文字幕免费高清在线观看| 亚洲在线电影| 欧美亚洲一级片| 圆产精品久久久久久久久久久| 国产精品s色| 欧美精品一区二区三区国产精品| 一区二区国产精品精华液| 久久视频在线| 精品国偷自产在线| 五月天激情丁香| 亚洲成av人片乱码色午夜| 日韩视频中文字幕| 欧美图片第一页| 久久香蕉网站| 精品精品欲导航| 日本50路肥熟bbw| 久久99国产精品久久99大师| 欧美一区二区福利在线| 手机看片国产精品| 日韩精品成人| 日韩一区和二区| 白嫩情侣偷拍呻吟刺激 | 成人高清免费观看| 久久综合中文色婷婷| 国产中文字幕在线视频| 久久久精品国产免大香伊| 天天综合色天天综合色hd| 超碰人人在线| 欧美日韩一区二区三区| 91好吊色国产欧美日韩在线| 网友自拍亚洲| 日韩一区二区三区在线| 一本色道综合久久欧美日韩精品| 成人激情视频| 97精品一区二区三区| 中文字幕乱码视频| 99精品视频一区二区三区| 永久免费精品视频网站| 福利影院在线看| 欧美日韩一本到| 欧美熟妇精品一区二区蜜桃视频| 成人看的羞羞网站| 色综合久久久久久中文网| 国产成人精品av久久| 美女视频黄免费的久久 | 日韩影视高清在线观看| 久久国产视频网站| 无码人妻av免费一区二区三区 | 欧美舌奴丨vk视频| 欧美sm美女调教| 日韩视频在线观看免费视频| 亚洲精品系列| 成人h猎奇视频网站| 青青草视频在线观看| 亚洲永久免费av| 天天干天天av| 久久夜色电影| 国模叶桐国产精品一区| 国产精品一级二级| 国产精品色在线| 免费裸体美女网站| 欧美调教在线| 欧美黑人性视频| 正在播放亚洲精品| 成人禁用看黄a在线| 激情五月五月婷婷| 国产亚洲人成a在线v网站 | 国产区在线观看| 欧美日韩视频在线| 玖草视频在线观看| 国产综合精品| 91精品久久久久久久久不口人| 四虎影视在线播放| 婷婷中文字幕一区三区| youjizz.com日本| 欧美高清不卡| 国产综合久久久久久| a天堂中文在线88| 欧美专区日韩专区| 一级片手机在线观看| 亚洲小说欧美另类婷婷| 成人免费视频网站| 国产99re66在线视频| 337p日本欧洲亚洲大胆精品 | 亚洲茄子视频| 99久久精品免费看国产四区| 午夜小视频在线观看| 日韩欧美成人午夜| 精品无码m3u8在线观看| 成人一区二区视频| 人妻av中文系列| 开心激情综合| 91av在线精品| 免费在线国产| 欧洲精品视频在线观看| 精品在线观看一区| 久草精品在线观看| 男女裸体影院高潮| 77成人影视| 1769国产精品| 成年人视频免费在线观看| 欧美日韩一区二区三区四区五区| 国产日产在线观看| 国产精品自拍一区| 亚洲国产一区二区三区在线播| 欧美成人一二区| 色哟哟亚洲精品一区二区| 国产日产亚洲系列最新| 亚洲国产成人tv| 在线不卡av电影| 美女久久久精品| 色播亚洲婷婷| 亚洲不卡在线| 欧美激情性做爰免费视频| 天天在线女人的天堂视频| 欧美性一区二区| 看片网站在线观看| 99国产一区二区三精品乱码| 精品免费国产一区二区| 欧美一区二区三区另类 | 色老汉av一区二区三区| www.4hu95.com四虎| 国产精品一级在线| 337p粉嫩大胆噜噜噜鲁| 99久久影视| 国产尤物99| 99精品在线免费观看| 国内精品一区二区三区| 香蕉视频免费在线播放| 亚洲成av人片在线观看香蕉| 最近中文字幕av| 亚洲国产日韩一级| 欧美a在线播放| 国产毛片精品国产一区二区三区| 各处沟厕大尺度偷拍女厕嘘嘘 | 日韩极品视频在线观看| 久久99久久人婷婷精品综合| 成人a级免费视频| 91久久国产综合久久91猫猫| 色综合男人天堂| 午夜激情视频在线| 日韩国产欧美精品一区二区三区| 在线视频一区二区三区四区| 一区二区三区**美女毛片| 国产综合精品久久久久成人av| 国产成人午夜精品影院观看视频| 国内自拍视频一区| 影音先锋久久精品| 一区二区三区日韩视频| 全球av集中精品导航福利| 成人免费午夜电影| 人人鲁人人莫人人爱精品| 久久免费观看视频| 午夜伦理在线视频| 久久精品国产视频| 最新97超碰在线| 亚洲图片欧美午夜| 色婷婷中文字幕| 精品国产青草久久久久福利| 国产精品久久免费| 欧美日韩国产区一| 天天干,天天干| 欧美午夜女人视频在线| 日韩欧美不卡视频| 国产精品不卡视频| 五月天精品视频| 久久综合色鬼综合色| 久久福利小视频| 成人av免费观看| 最新国产精品自拍| 九九久久精品视频| 午夜精品久久久内射近拍高清| 国产在线欧美| 国产婷婷一区二区三区| 亚洲网色网站| 超碰在线免费观看97| 欧美hentaied在线观看| 欧美日韩精品免费在线观看视频| 国语一区二区三区| 精品国产乱码久久久久软件| 红杏aⅴ成人免费视频| 成人免费91在线看| 美女午夜精品| 久久久国产精品一区二区三区| 中文字幕日韩在线| 国产精品久久久久久久小唯西川| av在线国产精品| 99在线视频首页| 999国产精品一区| 成人在线资源网址| 日韩三级成人| 99se婷婷在线视频观看| 大胆国模一区二区三区| 国产色视频一区| 成人午夜一级| 成人乱色短篇合集| 亚洲图色一区二区三区| 国产福利久久精品| 伊人精品一区| 日本在线一区| 色婷婷热久久| 天天做天天躁天天躁| 国产精品草草| 国产91在线视频观看| 日韩av高清在线观看| 中文字幕免费高清在线| 国模大尺度一区二区三区| 人妻 丝袜美腿 中文字幕| 久久综合国产精品| 国产一二三av| 一区二区三区视频在线看| 老妇女50岁三级| 亚洲国产精品影院| 激情网站在线观看| 91麻豆精品国产91久久久| 国产美女三级无套内谢| 亚洲国产欧美一区二区丝袜黑人 | 91在线一区| 国产欧美一区二区三区另类精品 | 成人日韩在线视频| 成人毛片在线观看| 蜜桃久久精品成人无码av| 亚洲欧美二区三区| 午夜精品一区二| 日韩网站在线看片你懂的| 三级毛片在线免费看| 亚洲香蕉成人av网站在线观看| 国产精品剧情一区二区在线观看| 欧美猛交免费看| 欧美成人a交片免费看| 18成人在线| 亚洲精品小区久久久久久| 91视频成人免费| 日韩高清国产一区在线| 午夜性福利视频| 国产精品女同一区二区三区| 国产一级黄色av| 制服.丝袜.亚洲.中文.综合| 熟妇人妻系列aⅴ无码专区友真希| 日韩亚洲欧美中文高清在线| 另类视频在线| 91亚洲精品一区| 亚洲+变态+欧美+另类+精品| 麻豆视频传媒入口| 国产日韩一区| 中文字幕制服丝袜| 国产精品国产精品国产专区不片| 日韩av在线天堂| 日韩视频免费观看高清完整版| 五月天婷婷在线视频| 欧美中文在线视频| 国产精品久av福利在线观看| 亚洲一区二区精品在线观看| 久久不射网站| 加勒比精品视频| 亚洲激情成人在线| 亚洲一区二区色| 亚洲一级一级97网| 亚洲欧美电影| 黄色91av| 国产欧美日本| 国产裸体视频网站| 亚洲欧美日韩久久| 91亚洲欧美激情| 日韩一区二区三区xxxx| 性欧美1819sex性高清| 久久精品国产第一区二区三区最新章节| 日韩欧美网站| the porn av| 91视频免费观看| 中文字幕在线观看免费视频| 欧美一区二区三区啪啪| 福利在线视频网站| 亚洲自拍偷拍色图| 五月天久久网站| 在线观看日本www| 欧美极品aⅴ影院| 无码人妻丰满熟妇区五十路| 亚洲免费电影在线观看| 亚洲成人人体| 色一情一区二区三区四区| 久久国产免费| 欧美一区二区三区粗大| 欧美午夜精品电影| 精品黄色免费中文电影在线播放| 国产欧美精品久久久| 婷婷色综合网| 超级砰砰砰97免费观看最新一期 | 欧美va在线观看| 亚洲精品9999| 毛片av一区二区| 青娱乐国产视频| 欧美高清www午色夜在线视频| av影片在线看| 91亚洲永久免费精品| 欧美日韩伦理在线免费| 一区二区三区视频在线观看免费| 国产精品国产三级国产普通话99| 国产免费一区二区三区最新不卡| 久精品免费视频| 日韩精品社区| 中文字幕永久视频| 国产精品进线69影院| 国产肥老妇视频| 欧美久久精品一级黑人c片| 一区二区网站| 免费在线激情视频| 国产精品久久久久影院色老大| 国产美女精品视频国产| 98视频在线噜噜噜国产| 欧美亚洲激情| 97人人模人人爽人人澡| 午夜视频一区在线观看| 国产区视频在线播放| 91亚洲精品久久久| 国产日韩专区| 三级黄色在线观看| 亚洲国产天堂久久国产91| а_天堂中文在线| 视频在线一区二区三区| 成人一区在线看| 国产免费一级视频| 麻豆成人在线看| 免费电影一区二区三区| 在线免费黄色小视频| 午夜免费久久看| 色开心亚洲综合| 久久av免费观看| 激情丁香综合五月| 国产无遮挡又黄又爽在线观看| 日韩福利视频在线观看| 亚洲爽爆av| aⅴ在线免费观看| 亚洲激情在线激情| 91吃瓜网在线观看|