HyperLinkColumn多参数问题

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...  
  }

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值