DataGrid中想實現這樣的效果
根據某一字段列的值動態改變按鈕的文本比如
點擊按鈕列自動更新某列原為的值為並將按鈕列的文本改為置
再按下自動更新某列原為的值為並將按鈕列的文本改為置
最終通過NamingContainer實現! 方法如下
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:DataGrid id=
DataGrid
runat=
server
AutoGenerateColumns=
False
>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<Columns>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:BoundColumn DataField=
HonoreeID
HeaderText=
ID
></asp:BoundColumn>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:BoundColumn DataField=
status
HeaderText=
狀態
>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<HeaderStyle Width=
px
></HeaderStyle>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</asp:BoundColumn>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:TemplateColumn HeaderText=
狀態是否為
>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<HeaderStyle HorizontalAlign=
Center
Width=
%
></HeaderStyle>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<ItemStyle HorizontalAlign=
Center
></ItemStyle>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<ItemTemplate>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:Label id=
lb
runat=
server
Visible=
false
Text=
<%# ((DataBinder
Eval(Container
DataItem
status
{
}
))==
)?
是
:
<font color=red>否</font>
%>
>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</asp:Label>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
<asp:Button ID=
changeState
Runat=
server
Text=
<%# ((DataBinder
Eval(Container
DataItem
status
{
}
))==
)?
轉為
:
轉為
%>
>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</asp:Button>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</ItemTemplate>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</asp:TemplateColumn>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</Columns>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
</asp:DataGrid>
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
後台
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
protected System
Web
UI
WebControls
DataGrid DataGrid
;
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
public int KeyID
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
get
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
object o =ViewState [
KeyID
];
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
if(o!=null)
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
return int
Parse(ViewState [
KeyID
]
ToString());
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
else
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
return
;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
set
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
ViewState [
KeyID
] = value;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
public int RowState
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
get
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{ return int
Parse(ViewState [
RowState
]
ToString());
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
set
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
ViewState [
RowState
] = value;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private void Page_Load(object sender
System
EventArgs e)
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
if(IsPostBack)
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{return ;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
getData();
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private void getData()
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
//SqlConnection con = new SqlConnection(ConfigurationSettings
AppSettings[
DsnPubs
]);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
SqlConnection con = new SqlConnection(System
Configuration
ConfigurationSettings
AppSettings[
Mblog
]);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
SqlCommand cmd;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
con
Open();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
cmd = new SqlCommand(
select * from dbo
Honoree
con);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
DataGrid
DataSource = cmd
ExecuteReader();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
DataGrid
DataBind();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
con
Close();
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private bool UpdateData(int ID
int OldState)
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
SqlConnection con = new SqlConnection(System
Configuration
ConfigurationSettings
AppSettings[
Mblog
]);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
SqlCommand cmd;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
con
Open();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
try
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
string strSql=
Update Honoree set Status={
} where HonoreeID={
}
;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
strSql=string
Format(strSql
(OldState==
?
:
)
ToString()
ID
ToString());
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
cmd = new SqlCommand(strSql
con);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
cmd
ExecuteNonQuery();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
cmd
Dispose();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
return true;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
catch
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
return false;
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
finally
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
con
Close();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
con
Dispose();
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
return false;
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/20c75/20c750f24f3425e9b1655bcb7831f1e8269e5781" alt=""
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
Web 窗體設計器生成的代碼#region Web 窗體設計器生成的代碼
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
override protected void OnInit(EventArgs e)
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
//
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
// CODEGEN: 該調用是 ASP
NET Web 窗體設計器所必需的
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
//
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
InitializeComponent();
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
base
OnInit(e);
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
data:image/s3,"s3://crabby-images/2f0e6/2f0e65dc681f1f42e96ce3be083dcbbf373adc08" alt=""
/**//// <summary>
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
/// 設計器支持所需的方法
不要使用代碼編輯器修改
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
/// 此方法的內容
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
/// </summary>
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
private void InitializeComponent()
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
this
DataGrid
ItemCreated += new System
Web
UI
WebControls
DataGridItemEventHandler(this
DataGrid
_ItemCreated);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
this
DataGrid
ItemDataBound += new System
Web
UI
WebControls
DataGridItemEventHandler(this
DataGrid
_ItemDataBound);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
this
Load += new System
EventHandler(this
Page_Load);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
#endregion
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private void DataGrid
_ItemCreated(object sender
System
Web
UI
WebControls
DataGridItemEventArgs e)
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
if(e
Item
ItemType==ListItemType
Item || e
Item
ItemType == ListItemType
AlternatingItem)
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
Button b=(Button)e
Item
FindControl(
changeState
);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
if(b!=null)
data:image/s3,"s3://crabby-images/ea849/ea849547a867604ad0c664a4fa5542ea0f63006c" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
b
Click+=new EventHandler(b_Click);
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/52192/52192932c9808421d1df4a577d13f27bad2f9d88" alt=""
}
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private void DataGrid
_ItemDataBound(object sender
System
Web
UI
WebControls
DataGridItemEventArgs e)
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
data:image/s3,"s3://crabby-images/a3b67/a3b67f14965ca845673184d0f5d11e7c904415db" alt=""
private void b_Click(object sender
EventArgs e)
data:image/s3,"s3://crabby-images/d3c87/d3c875b3552c3fb6c74111e1833d04928ba922fa" alt=""
{
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
Button but = (Button)sender;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
DataGrid dg = (DataGrid)but
NamingContainer
NamingContainer;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
//此處是關鍵!!即找到包含按鈕的命名容器的上層命名容器
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
if(dg == null) return;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
DataGridItem di =(DataGridItem)but
NamingContainer;
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
TableCell key= (TableCell)di
Cells[
];
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
TableCell state= (TableCell)di
Cells[
];
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
KeyID=(key==null)?
:int
Parse(key
Text);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
RowState=(state==null)?
:int
Parse(state
Text);
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
Response
Write(UpdateData(this
KeyID
this
RowState)
ToString());
data:image/s3,"s3://crabby-images/91408/914080ab2b3cc494c7e0bed2d469142df3f64e34" alt=""
getData();
data:image/s3,"s3://crabby-images/49ee8/49ee8a1b3282bcaecc2cb81439e57a60a41e9552" alt=""
}
From:http://tw.wingwit.com/Article/program/net/201311/13037.html