gridview 用了hyperlinkfield,想要根据显示内容控制是否超链接,能做到吗? 5
1个回答
展开全部
完全可以!!
如
GridView中HyperLink控件
<asp:TemplateField HeaderText="部材编号" ItemStyle-HorizontalAlign="Left">
<ItemTemplate>
<asp:LinkButton ID="lbtnMate_No" runat="server" Text='<%# Eval("material_no") %>' OnClick="lbHyTest_Click" PostBackUrl='<%# String.Format("~/Asp_Form/frm_LogoReveal_M.aspx?mate={0}", Eval("material_no")) %>'></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
上述代码中("~/Asp_Form/frm_LogoReveal_M.aspx?mate={0}", Eval("material_no"))这一句是指定该HyperLink要跳转的页面,且带有URL传递参数mate,mate的值就是GridView中HyperLink所显示的值。
然后再拖一个HyperLink的控件,命名为HyTest,不要显示;然后双击它,在它的onClick事件中编写跳转代码
protected void HyTest_Click(object sender, EventArgs e)
{
strMate_No = Request.QueryString["mate"].ToString().Trim();
//获取URL地址后面的参数mate,根据不同的值再做不同的处理
//例如mate=1要跳转到哪里,mate=2要跳转到哪里;又或者为空的时候不跳转
if(strMate=="1")
{
Response.Redirect("a.aspx");
}
else
{
Response.Redirect("b.aspx");
}
}
这个原理是点击GridView中的HyperLink,通过URL参数传递并且执行GridView之外的HyperLink的单击事件。
如
GridView中HyperLink控件
<asp:TemplateField HeaderText="部材编号" ItemStyle-HorizontalAlign="Left">
<ItemTemplate>
<asp:LinkButton ID="lbtnMate_No" runat="server" Text='<%# Eval("material_no") %>' OnClick="lbHyTest_Click" PostBackUrl='<%# String.Format("~/Asp_Form/frm_LogoReveal_M.aspx?mate={0}", Eval("material_no")) %>'></asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
上述代码中("~/Asp_Form/frm_LogoReveal_M.aspx?mate={0}", Eval("material_no"))这一句是指定该HyperLink要跳转的页面,且带有URL传递参数mate,mate的值就是GridView中HyperLink所显示的值。
然后再拖一个HyperLink的控件,命名为HyTest,不要显示;然后双击它,在它的onClick事件中编写跳转代码
protected void HyTest_Click(object sender, EventArgs e)
{
strMate_No = Request.QueryString["mate"].ToString().Trim();
//获取URL地址后面的参数mate,根据不同的值再做不同的处理
//例如mate=1要跳转到哪里,mate=2要跳转到哪里;又或者为空的时候不跳转
if(strMate=="1")
{
Response.Redirect("a.aspx");
}
else
{
Response.Redirect("b.aspx");
}
}
这个原理是点击GridView中的HyperLink,通过URL参数传递并且执行GridView之外的HyperLink的单击事件。
追问
不是模板列,就是hyperlinkfield,<asp:HyperLinkField DataNavigateUrlFields="DeviceName" DataNavigateUrlFormatString="CurAlert.aspx" DataTextField="AlertState" ;如果AlertState="无",就不连接;否则链接到CurAlert.aspx。
追答
这个就不清楚了!!
模板列还好办点
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
TableDI
2024-07-18 广告
2024-07-18 广告
VLOOKUP 是 Excel 中一个非常实用的函数,它允许用户在一个区域或表格的首列中查找特定值,并返回同一行中指定列中的值。当进行跨表匹配时,你可以使用 VLOOKUP 函数将两个不同表格中的数据关联起来。通过指定查找值、表格数组、列号...
点击进入详情页
本回答由TableDI提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询