中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

asp.net中Repeater控件用法筆記
來源:易賢網(wǎng) 閱讀:1321 次 日期:2014-10-13 09:52:02
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net中Repeater控件用法筆記”,方便廣大網(wǎng)友查閱!

大家可能都對datagrid比較熟悉,但是如果在數(shù)據(jù)量大的時候,我們就得考慮使用repeater作為我們的數(shù)據(jù)綁定控件了。Repeater控件與DataGrid (以及DataList)控件的主要區(qū)別是在于如何處理HTML。ASP.NET建立HTML代碼以顯示DataGrid控件,但Repeater允許開發(fā)人員決定如何顯示數(shù)據(jù)。所以,你可以選擇將數(shù)據(jù)顯示在一個HTML表格中或者一個順序列表中。這主要取決于你的選擇,但你必須將正確的HTML插入到 ASP.NET頁面中。

模板與DataList一樣,Repeater控件只支持模板。以下的模板可供選擇:

AlternatingItemTemplate: 指定如何顯示每一其它選項。

ItemTemplate: 指定如何顯示選項。(AlternatingItemTemplate可以覆蓋這一模板。)

HeaderTemplate: 建立如何顯示標題。

FooterTemplate: 建立如何顯示頁腳。

SeparatorTemplate: 指定如何顯示不同選項之間的分隔符。

你可以使用這些模板來顯示你希望的數(shù)據(jù)。唯一具有強制性的模板是ItemTemplate,所有其它的模板都是具有選擇性的。

對于處理一個數(shù)據(jù)源,Repeater控件具有與DataGrid與DataList相同的屬性:

DataMember:獲得或者設置與 Repeater 控件綁定的相應DataSource屬性的表格。

DataSource:獲得或者設置為 Repeater 顯示提供數(shù)據(jù)的數(shù)據(jù)源。

除此之外,還有一個Items屬性,你可以通過這一屬性編程訪問Repeater數(shù)據(jù)中單一選項。它返回一個RepeaterItemCollection對象,為一組RepeaterItem對象的集合,代表 Repeater 數(shù)據(jù)的每一行。

ASP.NET Web數(shù)據(jù)控件還有其它一個共性:它們都使用DataBind方法來生成用戶界面。調用這一方法可以返回并顯示數(shù)據(jù)(假設DataSource和 DataMember屬性設置正確)。在查看DataBind方法之前,我們先看看如何在一個Web頁面中使用一個Repeater控件。

使用Repeater控件

使用Repeater控件的第一步驟是決定我們將要使用的數(shù)據(jù)源和字段。例如,我們將要使用SQL Server Northwind數(shù)據(jù)庫中的Employees列表。Web頁面將顯示職工的完整名字,地址,以及電話號碼。HTML將使用DIV標記,用 Repeater 模板來分隔內容。下面是 Web 頁面的 HTML 內容:

前臺代碼

代碼如下:

<asp:Repeater ID="Repeater1" runat="server">

<HeaderTemplate><table cellpadding="0" cellspacing="0" border="1" align="center" class="auto-style1">

<tr align="left">

<th>編號</th>

<th>姓名</th>

<th>年齡</th>

<th>班級</th>

<th>零花</th>

</tr>

</HeaderTemplate>

<ItemTemplate>

<tr >

<td><%#Eval("id")%></td>

<td><%#Eval("name")%></td>

<td><%#Eval("age")%></td>

<td><%#Eval("classid")%></td>

<td><%#Eval("salary")%></td>

</tr>

</ItemTemplate>

<FooterTemplate></table></FooterTemplate>

</asp:Repeater>

后臺代碼

代碼如下:

string sql = string.Format("select * from person");

DataTable dt = sqlhelper.helper.ExecuteQuery(sql);

Repeater1.DataSource = dt;

Repeater1.DataBind();

AspNetpager的使用方法:

首先注冊<%@ Register Assembly="AspNetPager" Namespace="Wuqi.Webdiyer" TagPrefix="webdiyer" %>

前臺:

代碼如下:

<webdiyer:AspNetPager ID="AspNetPager1" runat="server" CustomInfoHTML="第%CurrentPageIndex%頁,共%PageCount%頁,每頁%PageSize%條"

FirstPageText="首頁" LastPageText="尾頁" LayoutType="Table" NextPageText="下一頁"

onpagechanging="AspNetPager1_PageChanging" PageIndexBoxType="DropDownList"

PagingButtonLayoutType="Span" PrevPageText="上一頁" ShowCustomInfoSection="Left"

ShowPageIndexBox="Always" SubmitButtonText="Go" TextAfterPageIndexBox="頁"

TextBeforePageIndexBox="轉到" Width="450px" PageSize="3">

</webdiyer:AspNetPager>

后臺:

代碼如下:

private void AddPages(Repeater rpt,Wuqi.Webdiyer.AspNetPager anp,DataTable dt)

{

PagedDataSource pds = new PagedDataSource();

pds.AllowPaging = true;

pds.DataSource = dt.DefaultView;

anp.RecordCount = dt.Rows.Count;//給分頁控件指定當前總數(shù)

pds.PageSize = anp.PageSize;//確定分頁,每頁有n項

pds.CurrentPageIndex = anp.CurrentPageIndex - 1;//確定當前頁數(shù)

rpt.DataSource = pds;//綁定數(shù)據(jù)源

rpt.DataBind();

}

protected void AspNetPager1_PageChanging(object src, Wuqi.Webdiyer.PageChangingEventArgs e)

{

AspNetPager1.CurrentPageIndex = e.NewPageIndex;

BindPersonData();

}

例子

repeater控件動態(tài)添加、刪除一行

代碼如下:

<script type="text/javascript">

var txtEquipmentIdsIDArray = new Array();

function OpenWindow(clientId, TypeId, ReqNum) {

var url = "../EquipmentIssue/EquipmentRequestIssue.aspx?TypeId=" + TypeId + "&ReqNum=" + ReqNum;

var widths = 600;

var heigths = 450;

var winPar = window.showModalDialog(url, window, 'dialogWidth=' + widths + 'px;dialogHeight=' + heigths + 'px;status=no;center=yes;scroll=no;help:No;');

if (winPar != undefined) {

var txtEquipmentIds = document.getElementById(clientId);

txtEquipmentIds.value = winPar;

// //審批用戶控件中保存發(fā)放的EquipmentId

// var IsExistEquipmentIdsID = false;

// for (var i = 0; i < txtEquipmentIdsIDArray.length; i++) {

// if (txtEquipmentIdsIDArray[i] == clientId) {

// IsExistEquipmentIdsID = true;

// }

// }

// if (IsExistEquipmentIdsID == false) {

// txtEquipmentIdsIDArray.push(clientId);

// }

// var tempEquipmentId = "";

// for (var i = 0; i < txtEquipmentIdsIDArray.length; i++) {

// tempEquipmentId = tempEquipmentId + document.getElementById(txtEquipmentIdsIDArray[i]).value;

// var hiddenEquipmentIds = document.getElementById("UC_ApprovalAction1_hfEquipmentIds");

// hiddenEquipmentIds.value = tempEquipmentId;

// }

// //alert(hiddenEquipmentIds.value);

}

var tempReturnValue = "";

var tb_Request = document.getElementById("tb_Request");

var tr = tb_Request.getElementsByTagName("tr");

for (var i = 0; i < tr.length; i++) {

if (tr[i].id != "") {

var span_EquRequestItemId = tr[i].getElementsByTagName("span"); //獲取申請明細的IDEquRequestItemId

var select_ddlStation; //獲取使用工位StationId

var option = tr[i].getElementsByTagName("select")[1].getElementsByTagName("option");

for (var j = 0; j < option.length; j++) {

if (option[j].selected)

{

select_ddlStation = option[j]

}

}

var textarea_EquipmentIds = tr[i].getElementsByTagName("textarea"); //獲取發(fā)放的資產號EquipmentNo

tempReturnValue = tempReturnValue + span_EquRequestItemId[0].innerText + ":" + select_ddlStation.value + ":" + textarea_EquipmentIds[0].innerText + "|";

}

}

var hiddenEquipmentIds = document.getElementById("UC_ApprovalAction1_hfEquipmentIds");

hiddenEquipmentIds.value = tempReturnValue;

//alert(hiddenEquipmentIds.value);

}

</script>

Repeater:

代碼如下:

<div id="div_Repeater">

<asp:HiddenField ID="hfRptColumns" runat="server" Value="Guid,EquRequestItemId,EquipmentType,Station,EquipmentNum,EquipmentIds" />

<table id="tb_Request" cellpadding="1" cellspacing="0" width="100%" style="background-color: #DFE8F6; font-size:12px; padding:10px;">

<thead>

<tr>

<th>序號</th>

<th>明細編號</th>

<th>

資產類型

</th>

<th>

使用工位

</th>

<th>

申請數(shù)量

</th>

<th>

發(fā)放的資產號<font color="red">(資產管理員填寫)</font>

</th>

</tr>

</thead>

<tbody>

<asp:Repeater ID="rptRequest" runat="server" onitemcommand="rptRequest_ItemCommand"

onitemdatabound="rptRequest_ItemDataBound">

<ItemTemplate>

<tr id="tr_Request">

<td>

<%# Container.ItemIndex+1 %>

<asp:Label ID="lblGuid" runat="server" Text='<%#Eval("Guid") %>' Visible="false"></asp:Label>

</td>

<td><asp:Label ID="lblEquRequestItemId" runat="server" Text='<%#Eval("EquRequestItemId") %>'></asp:Label></td>

<td>

<asp:DropDownList ID="ddlEquipmentType" runat="server"></asp:DropDownList>

<asp:Label ID="lblEquipmentType" runat="server" Text='<%#Eval("EquipmentType") %>' Visible="false"></asp:Label>

</td>

<td>

<asp:DropDownList ID="ddlStation" runat="server"></asp:DropDownList>

<asp:Label ID="lblStation" runat="server" Text='<%#Eval("Station") %>' Visible="false"></asp:Label>

</td>

<td><asp:TextBox ID="txtReqEquipmentNum" runat="server" Text='<%#Eval("EquipmentNum") %>'></asp:TextBox></td>

<td><asp:TextBox ID="txtEquipmentIds" runat="server" Text='<%#Eval("EquipmentIds") %>' TextMode="MultiLine"></asp:TextBox></td>

<td><asp:Button ID="btnAddRow" runat="server" Text="新增一行" CommandName="add" />

&nbsp;&nbsp;&nbsp;&nbsp;<asp:Button ID="btnDeleteRow" runat="server" Text="刪除本行" CommandName="delete" /></td>

</tr>

</ItemTemplate>

</asp:Repeater>

</tbody>

</table>

</div>

后臺:

代碼如下:

/// <summary>

/// 綁定repeater的數(shù)據(jù)源

/// </summary>

private void RepeaterBindData()

{

DataTable dt = DefineDataTableSchema(hfRptColumns.Value);

if (Request["BusinessNo"] == null)

{

LoadData(dt);

}

else

{

LoadData(Request["BusinessNo"].ToString(), dt);

}

rptRequest.DataSource = dt;

rptRequest.DataBind();

}

private void LoadData(string businessNo, DataTable dt)

{

string strSql = "select * from EMS_EquipmentRequestItem where BussinessNo = '"+ businessNo +"'";

DataTable dt_EquipmentRequestItem = DBUtility.DbHelperSQL.Query(strSql).Tables[0];

//for (int i = 0; i < dt_EquipmentRequestItem.Rows.Count; i++)

foreach (DataRow dr in dt_EquipmentRequestItem.Rows)

{

DataRow row = dt.NewRow();

row["Guid"] = Guid.NewGuid();

row["EquRequestItemId"] = dr["EquRequestItemId"].ToString();

row["EquipmentType"] = dr["TypeId"].ToString();

row["Station"] = dr["StationId"].ToString();

row["EquipmentNum"] = dr["EquipmentNum"].ToString();

row["EquipmentIds"] = dr["EquipmentIds"].ToString();

dt.Rows.Add(row);

}

}

/// <summary>

/// repeater數(shù)據(jù)默認加載

/// </summary>

/// <param name="dt"></param>

private void LoadData(DataTable dt)

{

//默認顯示1行

for (int i = 0; i < 1; i++)

{

DataRow row = dt.NewRow();

dt.Rows.Add(row);

}

//為第一行加載一些數(shù)據(jù)

DataRow row0 = dt.Rows[0];

row0["Guid"] = Guid.NewGuid();

row0["EquRequestItemId"] = "";

row0["EquipmentType"] = "";

row0["Station"] = "";

row0["EquipmentNum"] = "1";//默認初始為1

row0["EquipmentIds"] = "";

}

/// <summary>

/// 根據(jù)repeater相對應的列名,定義數(shù)據(jù)源datatable的schema

/// </summary>

/// <param name="columns">列名</param>

/// <returns></returns>

public DataTable DefineDataTableSchema(string columns)

{

DataTable dt = new DataTable();

string[] columnsAry = columns.Split(',');

foreach (string str in columnsAry)

{

dt.Columns.Add(str);

}

return dt;

}

protected void rptRequest_ItemCommand(object source, RepeaterCommandEventArgs e)

{

if (e.CommandName == "add")

{

System.Web.UI.WebControls.Label lblGuid = (System.Web.UI.WebControls.Label)e.Item.FindControl("lblGuid");

//首先,恢復數(shù)據(jù)源

DataTable dt = DefineDataTableSchema(hfRptColumns.Value);

foreach (RepeaterItem item in rptRequest.Items)

{

DataRow newRow = dt.NewRow();

newRow["Guid"] = ((System.Web.UI.WebControls.Label)item.FindControl("lblGuid")).Text;

newRow["EquRequestItemId"] = ((System.Web.UI.WebControls.Label)item.FindControl("lblEquRequestItemId")).Text;

newRow["EquipmentType"] = ((DropDownList)item.FindControl("ddlEquipmentType")).SelectedValue;

newRow["Station"] = ((DropDownList)item.FindControl("ddlStation")).SelectedValue;

newRow["EquipmentNum"] = ((TextBox)item.FindControl("txtReqEquipmentNum")).Text;

newRow["EquipmentIds"] = ((TextBox)item.FindControl("txtEquipmentIds")).Text;

dt.Rows.Add(newRow);

if (lblGuid.Text == ((System.Web.UI.WebControls.Label)item.FindControl("lblGuid")).Text)

{

//添加一行

DataRow row = dt.NewRow();

row["Guid"] = Guid.NewGuid();

row["EquipmentType"] = "";

row["Station"] = "";

row["EquipmentNum"] = "1";//默認初始為1

row["EquipmentIds"] = "";

dt.Rows.Add(row);

}

}

rptRequest.DataSource = dt;

rptRequest.DataBind();

}

else if (e.CommandName == "delete")

{

System.Web.UI.WebControls.Label lblGuid = (System.Web.UI.WebControls.Label)e.Item.FindControl("lblGuid");

//首先,恢復數(shù)據(jù)源

DataTable dt = DefineDataTableSchema(hfRptColumns.Value);

foreach (RepeaterItem item in rptRequest.Items)

{

if (lblGuid.Text != ((System.Web.UI.WebControls.Label)item.FindControl("lblGuid")).Text)

{

DataRow newRow = dt.NewRow();

newRow["Guid"] = ((System.Web.UI.WebControls.Label)item.FindControl("lblGuid")).Text;

newRow["EquRequestItemId"] = ((System.Web.UI.WebControls.Label)item.FindControl("lblEquRequestItemId")).Text;

newRow["EquipmentType"] = ((DropDownList)item.FindControl("ddlEquipmentType")).SelectedValue;

newRow["Station"] = ((DropDownList)item.FindControl("ddlStation")).SelectedValue;

newRow["EquipmentNum"] = ((TextBox)item.FindControl("txtReqEquipmentNum")).Text;

newRow["EquipmentIds"] = ((TextBox)item.FindControl("txtEquipmentIds")).Text;

dt.Rows.Add(newRow);

}

}

rptRequest.DataSource = dt;

rptRequest.DataBind();

}

}

protected void rptRequest_ItemDataBound(object sender, RepeaterItemEventArgs e)

{

if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)

{

DropDownList ddlEquipmentType_temp = e.Item.FindControl("ddlEquipmentType") as DropDownList;

string sqlstr = @"select distinct b.TypeId,b.EquipmentName + '_' + b.EquipmentType as 'EquipmentName_EquipmentType'

from EMS_EquipmentInfo a

join EMS_EquipmentType b on a.TypeId = b.TypeId and b.Status = '1'

order by EquipmentName_EquipmentType";

DataSet ds = DBUtility.DbHelperSQL.Query(sqlstr);

ddlEquipmentType_temp.DataTextField = "EquipmentName_EquipmentType";

ddlEquipmentType_temp.DataValueField = "TypeId";

ddlEquipmentType_temp.DataSource = ds;

ddlEquipmentType_temp.DataBind();

ddlEquipmentType_temp.SelectedValue = (e.Item.FindControl("lblEquipmentType") as System.Web.UI.WebControls.Label).Text;

DropDownList ddlStation_temp = e.Item.FindControl("ddlStation") as DropDownList;

string sqlstr2 = @"select NodeId,Line + '_' + StationName as 'Line_StationName' from V_Stations where status='1' order by Line_StationName";

DataSet ds2 = DBUtility.DbHelperSQL.Query(sqlstr2);

ddlStation_temp.DataTextField = "Line_StationName";

ddlStation_temp.DataValueField = "NodeId";

ddlStation_temp.DataSource = ds2;

ddlStation_temp.DataBind();

ddlStation_temp.SelectedValue = (e.Item.FindControl("lblStation") as System.Web.UI.WebControls.Label).Text;

TextBox txtEquIds = e.Item.FindControl("txtEquipmentIds") as TextBox;

txtEquIds.Attributes.Add("readonly", "true");

if (Request["BusinessNo"] != null)

{

(e.Item.FindControl("btnAddRow") as System.Web.UI.WebControls.Button).Visible = false;

(e.Item.FindControl("btnDeleteRow") as System.Web.UI.WebControls.Button).Visible = false;

string businessNo = Request["BusinessNo"].ToString();

bool IsApplyUser = Is_ApplyUser(Session["currentUserID"].ToString(), businessNo, "EMS_EquipmentRequest", "Requester");//是否為申請人本人

if (IsApplyUser == true)

{

string requestStatus = HttpUtility.UrlDecode(Request["RequestStatus"].ToString(), System.Text.Encoding.UTF8);//申請單的當前狀態(tài)

if (requestStatus == "草稿" || requestStatus == "退回")

{

(e.Item.FindControl("btnAddRow") as System.Web.UI.WebControls.Button).Visible = true;

(e.Item.FindControl("btnDeleteRow") as System.Web.UI.WebControls.Button).Visible = true;

}

}

else

{

bool IsCurrentAppprovaler = Is_CurrentAppprovaler(Session["currentUserID"].ToString(), businessNo);//是否為當前能做審批的人

if (IsCurrentAppprovaler == true)

{

string sql = " SELECT TOP 1 LayerName from EMS_Approvaler where BussinessNo='" + businessNo + "' "

+ " AND ApprovalStatus='N' ORDER BY AppSequence ";

DataTable dt = DBUtility.DbHelperSQL.Query(sql).Tables[0];

if (dt.Rows.Count != 0 && dt.Rows[0]["LayerName"].ToString() == "資產管理員")

{

string ReqNum = (e.Item.FindControl("txtReqEquipmentNum") as TextBox).Text.Trim();

txtEquIds.Attributes.Add("onclick", "OpenWindow('" + txtEquIds.ClientID + "','" + ddlEquipmentType_temp.SelectedValue + "','" + ReqNum + "')");

}

}

}

}

}

}

更多信息請查看IT技術專欄

更多信息請查看網(wǎng)絡編程
易賢網(wǎng)手機網(wǎng)站地址:asp.net中Repeater控件用法筆記

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
99热在线精品观看| 国产一区二区成人| 国产欧美日韩综合精品二区| 在线亚洲激情| 国产精品久久久久婷婷| 亚洲伊人观看| 国模精品一区二区三区| 免费欧美电影| 亚洲午夜电影网| 国产在线精品二区| 麻豆久久婷婷| 亚洲欧美国产日韩中文字幕| 红桃视频国产一区| 欧美肉体xxxx裸体137大胆| 午夜精品在线看| 亚洲国产精品一区二区第四页av| 欧美日韩四区| 裸体一区二区三区| 在线中文字幕不卡| 精品成人在线| 国产精品视频你懂的| 女同性一区二区三区人了人一| 99视频在线精品国自产拍免费观看| 国产美女精品人人做人人爽| 欧美激情黄色片| 久久久久九九九| 亚洲综合色婷婷| 亚洲国产成人在线| 国产欧美日韩在线 | 亚洲日本视频| 国产精品久久国产精品99gif| 久久久久久久国产| 亚洲欧美视频一区| 亚洲精品自在在线观看| 一色屋精品亚洲香蕉网站| 欧美三级电影精品| 欧美极品在线观看| 欧美.www| 麻豆精品精品国产自在97香蕉| 亚洲女同同性videoxma| 中国日韩欧美久久久久久久久| 亚洲国产欧美不卡在线观看| 韩日精品视频| 激情亚洲网站| 国产一区二区精品久久99| 国产精品久久久久久久久久ktv| 欧美高清视频在线| 欧美11—12娇小xxxx| 久久综合狠狠综合久久综青草 | 久久成人精品一区二区三区| 亚洲午夜在线| 亚洲一区二区在线观看视频| 一区二区三区视频在线| 99精品视频一区| 夜夜嗨av一区二区三区四区| 亚洲精品中文字幕女同| 亚洲精品在线看| 日韩亚洲国产欧美| 一本久道久久综合婷婷鲸鱼| 一区二区动漫| 亚洲永久在线| 久久国产精品毛片| 久久一本综合频道| 欧美阿v一级看视频| 欧美精品日韩精品| 欧美三级小说| 国产乱码精品1区2区3区| 国产偷久久久精品专区| 黄色成人小视频| 亚洲成色最大综合在线| 亚洲免费成人| 亚洲一区图片| 久久精品天堂| 欧美国产日韩a欧美在线观看| 欧美精品三区| 国产精品一区三区| 在线观看免费视频综合| 日韩一区二区免费高清| 亚洲欧美国产视频| 久久久久久九九九九| 欧美激情视频网站| 久久久久久久成人| 精品99一区二区| 亚洲人成毛片在线播放| 中文在线不卡| 久久亚洲一区| 欧美日韩国产综合一区二区| 国产女精品视频网站免费 | 久久久亚洲一区| 欧美日韩三区四区| 国产嫩草一区二区三区在线观看| 在线免费不卡视频| 亚洲永久免费视频| 美国十次了思思久久精品导航| 欧美日韩免费区域视频在线观看| 国产精品久久二区| 亚洲国产精品久久久久久女王| 亚洲一区二区欧美日韩| 久久综合国产精品| 国产精品美女999| 91久久在线| 久久免费99精品久久久久久| 国产精品国产三级国产专播品爱网 | 久久综合狠狠| 国产欧美日韩精品在线| 99re6这里只有精品视频在线观看| 欧美在线欧美在线| 国产精品高潮呻吟久久| 亚洲精品资源| 欧美成人午夜77777| 国内精品久久久久久久果冻传媒| 一区二区毛片| 欧美日韩精品一区二区三区四区 | 午夜精品国产更新| 欧美日韩mv| 亚洲黄色一区二区三区| 久久久久久综合| 国模私拍一区二区三区| 亚洲一区二区欧美日韩| 欧美日韩亚洲一区三区| 亚洲人成网站色ww在线| 久久夜色精品国产欧美乱极品| 国产真实久久| 久久精品亚洲| 亚洲国产精品黑人久久久| 91久久极品少妇xxxxⅹ软件| 香蕉久久国产| 国产农村妇女毛片精品久久莱园子 | 亚洲国产精品悠悠久久琪琪| 国产亚洲在线| 亚洲黄一区二区三区| 麻豆精品在线观看| 亚洲高清自拍| 欧美二区在线| 亚洲精品影视| 欧美日韩一区二区在线| 一区二区日韩精品| 欧美日韩国产综合视频在线观看中文| 最新中文字幕一区二区三区| 欧美国产亚洲精品久久久8v| 亚洲精选视频免费看| 欧美日韩亚洲国产精品| 亚洲性感美女99在线| 国产九九视频一区二区三区| 久久爱www.| 亚洲第一黄色| 欧美日韩国产影片| 亚洲午夜精品网| 国产欧美一区二区精品性| 欧美在线高清| 亚洲成人在线视频播放| 欧美剧在线免费观看网站| 中文在线资源观看网站视频免费不卡| 国产精品成人va在线观看| 欧美一区二区三区在线看| 精品成人一区二区三区四区| 欧美激情五月| 午夜精品久久久久久久蜜桃app | 狠狠色综合色综合网络| 欧美xx69| 亚洲欧美精品在线观看| 一区二区三区在线视频播放| 欧美激情精品久久久久| 亚洲一区二区三| 精品51国产黑色丝袜高跟鞋| 免费中文字幕日韩欧美| 亚洲性av在线| 永久免费视频成人| 夜夜夜精品看看| 国产一区二区成人| 欧美精品在线视频观看| 久久精品国产999大香线蕉| 亚洲一区二区视频在线| 极品裸体白嫩激情啪啪国产精品| 中文国产一区| 久久综合一区| 亚洲全部视频| 韩国三级电影一区二区| 国产欧美一区二区精品仙草咪| 欧美三级视频在线播放| 亚洲一区中文| 亚洲精品久久久久中文字幕欢迎你| 激情成人av在线| 羞羞色国产精品| 国产三级精品三级| 欧美在线免费观看视频| 国产在线麻豆精品观看| 亚洲一区二区免费| 欧美日韩精品免费| 亚洲欧美日韩精品一区二区| 亚洲电影在线| 国产精品美女主播在线观看纯欲| 裸体素人女欧美日韩| 亚洲制服av| 99国产精品国产精品久久| 亚洲第一在线综合在线| 国产日韩欧美综合| 国产精品欧美风情| 欧美日韩一区二区国产| 久久综合久久综合久久综合|