1使用DataGrid的时候如果你有一个asp:HyperLinkColumn又想使用多个需要绑定的参数作为链接的url,那么请改成模板列,使用普通的link标签<a>或者asp:HyperLink都可以,下面2种实现多绑定参数的解决方案。
(1)后台返回url
前台
<asp:TemplateColumn HeaderText="打开">
<ItemTemplate>
<asp:HyperLink Text="打开" NavigateUrl='<%# myfunc2(DataBinder.Eval(Container.DataItem,"vName"),DataBinder.Eval(Container.DataItem,"iAge"))%> ' Runat="server" Target="_blank" ID="Hyperlink1">
</asp:HyperLink>
</ItemTemplate>
</asp:TemplateColumn>
后台
protected string myfunc2(object s1,object s2)
{
return "newpage.aspx?name="+s1.ToString()+"&age="+s2.ToString();
}
(2)直接前台设定url
<asp:TemplateColumn HeaderText="打开">
<ItemTemplate>
<asp:HyperLink Text="打开" NavigateUrl='<%#"newpage.aspx?name="+DataBinder.Eval(Container.DataItem, "vname")+"&age="+DataBinder.Eval(Container.DataItem, "iage") %>' Runat="server" Target="_blank">
</asp:HyperLink>
</ItemTemplate>
</asp:TemplateColumn>
其实以上2个方案是一回事情,但是前者更加清晰,而且易于后台动态生成url。
2(1)用hyperlinkcolumn.
在itemdatabound里面写咯
if(e.item.itemindex>=0)
{
HyperLink hp = hp(e.item.cells[hpbutton列序数].findcontrol[hpbuttonID]);
hp.NavigateUrl = "***.aspx?bd1="+dropdownlist.selectvalue+"&bd2="+e.item.cells[绑定字段列序数].text;
}
(2)
foreach (DataGridItem item in dg.Items)
{
// 取到你的链接列
//item.cells[3].Controls[0]
// 转换为链接控件
// 赋值 - url, text...
}