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

asp.net中repeater控件用法筆記
來源:易賢網 閱讀:1127 次 日期:2015-01-15 13:33:34
溫馨提示:易賢網小編為您整理了“asp.net中repeater控件用法筆記”,方便廣大網友查閱!

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

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

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

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

headertemplate: 建立如何顯示標題。

footertemplate: 建立如何顯示頁腳。

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

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

對于處理一個數據源,repeater控件具有與datagrid與datalist相同的屬性:

datamember:獲得或者設置與 repeater 控件綁定的相應datasource屬性的表格。

datasource:獲得或者設置為 repeater 顯示提供數據的數據源。

除此之外,還有一個items屬性,你可以通過這一屬性編程訪問repeater數據中單一選項。它返回一個repeateritemcollection對象,為一組repeateritem對象的集合,代表 repeater 數據的每一行。

asp.net web數據控件還有其它一個共性:它們都使用databind方法來生成用戶界面。調用這一方法可以返回并顯示數據(假設datasource和 datamember屬性設置正確)。在查看databind方法之前,我們先看看如何在一個web頁面中使用一個repeater控件。

使用repeater控件

使用repeater控件的第一步驟是決定我們將要使用的數據源和字段。例如,我們將要使用sql server northwind數據庫中的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;//給分頁控件指定當前總數

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

pds.currentpageindex = anp.currentpageindex - 1;//確定當前頁數

rpt.datasource = pds;//綁定數據源

rpt.databind();

}

protected void aspnetpager1_pagechanging(object src, wuqi.webdiyer.pagechangingeventargs e)

{

aspnetpager1.currentpageindex = e.newpageindex;

bindpersondata();

}

例子

repeater控件動態添加、刪除一行

代碼如下:

<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;

// //審批用戶控件中保存發放的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); //獲取發放的資產號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>

申請數量

</th>

<th>

發放的資產號<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的數據源

/// </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數據默認加載

/// </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);

}

//為第一行加載一些數據

datarow row0 = dt.rows[0];

row0[guid] = guid.newguid();

row0[equrequestitemid] = ;

row0[equipmenttype] = ;

row0[station] = ;

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

row0[equipmentids] = ;

}

/// <summary>

/// 根據repeater相對應的列名,定義數據源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);

//首先,恢復數據源

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);

//首先,恢復數據源

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);//申請單的當前狀態

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技術專欄

更多信息請查看網頁制作
易賢網手機網站地址:asp.net中repeater控件用法筆記
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

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

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
久久精品视频网| 亚洲九九精品| 久久精品夜色噜噜亚洲a∨ | 国产精品video| 欧美激情精品久久久| 久热成人在线视频| 欧美一区二区三区四区在线观看地址| 制服丝袜激情欧洲亚洲| 永久91嫩草亚洲精品人人| 在线观看国产成人av片| 亚洲激情在线视频| 亚洲午夜电影在线观看| 欧美成人精品福利| 国产真实久久| 亚洲欧美日韩在线一区| 欧美日韩免费视频| 亚洲精品美女| 欧美99在线视频观看| 国产日韩欧美在线视频观看| 野花国产精品入口| 欧美激情精品| 亚洲欧洲偷拍精品| 欧美大胆人体视频| 国内精品久久久久伊人av| 亚洲影院色无极综合| 欧美日韩国产亚洲一区| 亚洲精品在线观看免费| 你懂的一区二区| 亚洲电影观看| 久久伊伊香蕉| 加勒比av一区二区| 久久精品1区| 国产亚洲午夜| 久久久久久久综合色一本| 国产欧美日韩一区二区三区在线| 亚洲一区视频| 国产精品视频1区| 午夜激情综合网| 国产精品日韩专区| 欧美在线|欧美| 黄色精品一区| 欧美va亚洲va日韩∨a综合色| 欧美激情亚洲精品| 亚洲精品乱码久久久久| 欧美日韩性生活视频| 日韩亚洲欧美综合| 欧美午夜无遮挡| 亚洲国产清纯| 欧美日韩一区二区三区在线看 | 亚洲黄色性网站| 欧美三级电影精品| 亚洲三级色网| 国产精品乱码人人做人人爱| 午夜免费电影一区在线观看| 国内一区二区三区在线视频| 久久全国免费视频| 亚洲美女区一区| 国产精品天天看| 久久久久久久国产| 最新亚洲激情| 国产精品日韩在线播放| 久久免费国产精品1| 亚洲欧洲中文日韩久久av乱码| 欧美精品偷拍| 欧美在线国产| 亚洲精品日产精品乱码不卡| 国产精品欧美久久| 免费欧美日韩| 午夜精品福利在线| 亚洲国产日韩在线一区模特| 国产精品久线观看视频| 久久夜色精品亚洲噜噜国产mv| 欧美美女bb生活片| 亚洲欧美日韩在线播放| 亚洲第一偷拍| 国产麻豆视频精品| 欧美另类专区| 久久人人97超碰精品888| 夜久久久久久| 悠悠资源网亚洲青| 国产精品网站一区| 欧美日韩hd| 久久综合国产精品| 欧美一区二区精品久久911| 亚洲精品欧美精品| 激情91久久| 国产欧美午夜| 欧美亚州在线观看| 欧美日韩成人精品| 久热精品视频在线观看| 欧美一区二区三区婷婷月色 | 欧美日韩ab| 久久午夜激情| 欧美中文字幕不卡| 亚洲一区二区视频在线观看| 亚洲精品久久久久| 激情欧美亚洲| 国产日韩欧美另类| 欧美视频免费在线观看| 欧美交受高潮1| 欧美国产日韩一区二区三区| 久久色中文字幕| 久久精品免费| 久久久久久999| 久久精品国产久精国产爱| 欧美在线免费看| 久久超碰97中文字幕| 欧美在线日韩在线| 欧美在线观看一二区| 欧美亚洲免费在线| 午夜精品视频一区| 亚洲欧美电影院| 性欧美video另类hd性玩具| 亚洲欧美日韩国产综合精品二区| 亚洲视频在线观看免费| 99这里有精品| 亚洲女人天堂成人av在线| 亚洲一区久久| 久久精品国产99国产精品| 黄色成人在线| 国产精品二区影院| 国产精品视频999| 国产一区二区欧美日韩| 一区三区视频| 亚洲另类在线视频| 一区二区三区视频在线 | 国产精品视频xxxx| 国产精品女主播在线观看| 国产一区二区久久精品| 亚洲高清一区二区三区| 亚洲精品永久免费| 亚洲综合视频1区| 久久精品亚洲国产奇米99| 老妇喷水一区二区三区| 欧美日韩国产va另类| 国产精品国产三级国产普通话蜜臀| 欧美性做爰毛片| 合欧美一区二区三区| 91久久国产精品91久久性色| 一区二区av| 久久久久久日产精品| 欧美日韩一区二| 免费在线国产精品| 国产精品一二三视频| 尤物九九久久国产精品的分类| 亚洲精品乱码久久久久久按摩观 | 欧美与欧洲交xxxx免费观看| 久久综合色一综合色88| 欧美激情日韩| 国产亚洲欧美一区二区三区| 亚洲国产电影| 亚洲欧美另类在线| 欧美高清在线精品一区| 国产精品资源在线观看| 亚洲欧洲日韩在线| 欧美在线一二三四区| 欧美精品久久久久久久久久| 国产婷婷一区二区| 亚洲一级二级| 欧美精品在线视频观看| 伊人久久av导航| 久久国产精品网站| 国产精品久久网| 一区二区国产精品| 欧美久久久久久久久久| 在线观看成人av| 久久成人资源| 国产精品三级久久久久久电影| 亚洲美女黄色片| 免费黄网站欧美| 在线观看亚洲视频啊啊啊啊| 午夜天堂精品久久久久| 国产精品分类| 亚洲在线成人精品| 国产乱肥老妇国产一区二| 亚洲午夜成aⅴ人片| 欧美色一级片| 一区二区免费看| 欧美日韩一区国产| 日韩午夜精品视频| 欧美精品一区二区精品网| 亚洲国产欧美一区二区三区同亚洲| 久久精品视频在线| 国内精品嫩模av私拍在线观看 | 欧美日韩综合精品| 亚洲精品久久久久中文字幕欢迎你 | 亚洲精品免费看| 欧美国产日韩二区| 亚洲精品乱码久久久久久按摩观| 久久免费视频在线| 亚洲国产精品一区在线观看不卡 | 欧美中文字幕第一页| 国产精品日本精品| 亚洲欧美国产精品桃花| 国产精品卡一卡二卡三| 欧美一区二区黄| 在线成人黄色| 欧美日本在线看| 亚洲尤物在线视频观看| 国模套图日韩精品一区二区|