<asp:HyperLinkColumn Target="_blank" DataNavigateUrlFormatString="Remit.aspx?BespeakID={8}" DataTextField="nID" HeaderText="汇款"></asp:HyperLinkColumn>
我根据一个条件判断后,链接列显示的内容为"汇款","已汇款",如果显示为"汇款",可以链接到remit.aspx页,如果显示"已汇款",刚不显示链接标志,求助,怎样实现?
我根据一个条件判断后,链接列显示的内容为"汇款","已汇款",如果显示为"汇款",可以链接到remit.aspx页,如果显示"已汇款",刚不显示链接标志,求助,怎样实现?
(1)当数据符合一定的条件需要修改它的呈现方式
(2)将数据库中的逻辑值(0,1)变成男女来呈现等等
大致有2种方法来实现上述操作
(1)在ItemDataBound中修改值
(2)在绑定的时候用一个函数进行过虑
同样,数据库按照 http://blog.csdn.net/lovecherry/archive/2005/02/25/301441.aspx
我们来实现以下2个功能
(1)在ItemDataBound中把年龄小于30的人的一行底色修改为粉红色
代码如下
private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
if(e.Item.ItemType==ListItemType.Item||e.Item.ItemType==ListItemType.AlternatingItem||e.Item.ItemType==ListItemType.EditItem)
{
if(Convert.ToInt16(DataBinder.Eval(e.Item.DataItem,"iAge"))<30)e.Item.BackColor=Color.Pink;
}
}
当然需要注册事件
this.DataGrid1.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(this.DataGrid1_ItemDataBound);
(2)把姓名为“朱晔”的人,用加重显示
前台代码
<%#DataBinder.Eval(Container.DataItem,"vName") %>
修改为
<%# myfunc(DataBinder.Eval(Container.DataItem,"vName")) %>
后台代码
protected string myfunc(object s)
{
string _s;
if(s.ToString()=="朱晔")
_s="<b>"+s.ToString()+"</b>";
else
_s=s.ToString();
return _s;
}以上2种功能也就是我上面说的大致有2种方法来实现上述操作
就这么简单。
对于其他的一些相关扩展就不细说了
比如根据一个值来改变一些控件的属性:
如果控件是模板列中的可以通过((控件类型)e.Item.FindControl(id)).属性=值 来动态设定;
如果控件不是模板列中的可以通过((控件类型)e.Item.Controls[索引号]).属性=值 来动态设定
还比如根据一个列的值来写其他列的统计值,都一样的
在ItemDataBound事件方法中进行操作,因为这个时候数据绑定
HTML代码:
<asp:TemplateColumn>
<ItemTemplate>
<asp:HyperLink id="HyperLink1" Text='<%#DataBinder.Eval(Container.DataItem,"汇款字段")%>' NavigateUrl='<%#Link(Convert.ToString(DataBinder.Eval(Container.DataItem,"汇款字段")),Convert.ToString(DataBinder.Eval(Container.DataItem,"nID")))%>' runat="server">
</asp:HyperLink>
</ItemTemplate>
</asp:TemplateColumn>
CS代码:
public string Link(string str,string BespeakID)
{
if(str.Equals("汇款"))
{
return "Remit.aspx?BespeakID="+ BespeakID;
}
else
{
return "";
}
}
我并没有"汇款字段",是通过到另一个表中查询是否存在此表中的ID号来决定显示"汇款","未汇款"这样一来是不是又要加入相应的函数了呢!