DataGrid中實(shí)現(xiàn)超鏈接的3種方法
1.使用DataGrid中的超鏈接列—HyperLinkColumn
相信很多人都使用過(guò)datagrid中的超鏈接列,它很好用,默認(rèn)情況下只能傳遞一個(gè)參數(shù),如下所示:
<asp:HyperLinkColumn DataTextField="CompanyName" DataNavigateUrlField="CustomerID" DataNavigateUrlFormatString="Default2.aspx?customerid={0}" eaderText="link">
</asp:HyperLinkColumn>
從上可以看出,傳遞一個(gè)參數(shù)的超鏈接是很容易做到的。那么傳遞多個(gè)參數(shù)該如何做?
2.在DataGrid的ItemDataBound事件中對(duì)超鏈接列賦值
假設(shè)有一個(gè)id為DataGrid1的Datagrid,第一列為超鏈接列(下標(biāo)為0),那么它的ItemDataBound事件可寫(xiě)成下面形式。
private void DataGrid1_ItemDataBound(object sender,System.Web.UI.WebControls.DataGridItemEventArgs e)
{
if(e.Item.ItemType==ListItemType.Pager||e.Item.ItemType==ListItemType.Header||e.Item.ItemType==ListItemType.Footer)
{
return; //判斷是否為頁(yè)眉,頁(yè)腳
}
else
{
HyperLink link=( HyperLink)e.Item.Cells[0].Controls[0];//這里也可以用findcontrol
link.NavigateUrl="webform3.aspx?id=XXX & name=XXX";
//如果跟某列有關(guān),則可寫(xiě)為
// link.NavigateUrl="webform3.aspx?id=”+e.Item.Cells[列號(hào)].text;
}
}
如果想在模版列使用超鏈接,可以在該列模版設(shè)為L(zhǎng)inkButton,可以多個(gè)LinkButton在一起,不過(guò)id不能相同。我們?nèi)约俣ㄔ摿形皇堑谝涣?,此時(shí),為其中某個(gè)LinkButton定義鏈接可以如下,把語(yǔ)句
HyperLink link=( HyperLink)e.Item.Cells[0].Controls[0];
替換成
LinkButton link=( LinkButton)e.Item.Cells[0]. FindControl(“LinkButton的id”);
link.Attributes["onclick"] = "<script>location.href='XXX.aspx';</script>";
當(dāng)該列只有一個(gè)控件即一個(gè)LinkButton時(shí),可以用如下語(yǔ)句來(lái)實(shí)現(xiàn):
e.Item.Cells[0].Attributes["onclick"] = "<script>location.href='XXX.aspx';</script>";
這樣就省去查找控件的時(shí)間。
上面實(shí)際我們已經(jīng)說(shuō)到兩種方法,一種利用HyperLinkColumn列在ItemDataBound事件里添加NavigateUrl,另一種是在ItemDataBound事件中使用javascript定義click事件,后者比較靈活,只需控件有click事件即可。
3.使用HTML超鏈接標(biāo)記
<asp:TemplateColumn>
<ItemTemplate>
<a href="Default.aspx?id='<%#(String)DataBinder.Eval(Container.DataItem,"CustomerID")%>'
&name='<%#(String)DataBinder.Eval(Container.DataItem,"CompanyName")%>'">操作</a>
</ItemTemplate>
</asp:TemplateColumn>
它功能就是點(diǎn)擊時(shí)轉(zhuǎn)到Default.aspx,同時(shí)傳遞參數(shù)id和name,這里兩個(gè)參數(shù)都是通過(guò)數(shù)據(jù)綁定動(dòng)態(tài)生成。這種方法在VS2005中是成功的,但是在VS2003中卻報(bào)錯(cuò)。
還有一種方法很巧妙,它同樣實(shí)現(xiàn)第三種方法的功能:假設(shè)第二列做為超鏈接,aspx頁(yè)面代碼:
<asp:boundcolumn DataField="ID" Visible=False></asp:boundcolumn> //第一列
<asp:boundcolumn DataField="名稱"></asp:boundcolumn>//第二列
ItemDataBound事件如下:
public void DataGrid1_ItemDataBound(object sender,DataGridItemEventArgs e)
{
if(e.Item.ItemType==ListItemType.Pager||e.Item.ItemType==ListItemType.Header||e.Item.ItemType==ListItemType.Footer)
{
return;//判斷是否為頁(yè)眉,頁(yè)腳
}
else
{
e.Item.Cells[1].Text="<a href=News.aspx?ID="+e.Item.Cells[0].Text+">"+e.Item.Cells[1].Text+"</a>";//這里可以改成你需要的;
}
}
相關(guān)文章
asp.net core 集成swagger ui的原理解析
本文主要講解了如何對(duì)API進(jìn)行分組,這里僅僅是舉了一個(gè)按照API功能進(jìn)行分組的例子,其實(shí)在實(shí)際開(kāi)發(fā)中,要按照何種方式分組,可以按照需求靈活定義,比如按照API版本進(jìn)行分組2021-10-10
.NET?Core使用APB?vNext框架入門(mén)教程
這篇文章介紹了.NET?Core使用APB?vNext框架的入門(mén)教程,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
深入淺析ASP在線壓縮access數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了ASP在線壓縮access數(shù)據(jù)庫(kù)的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
根據(jù)控件Id得到控件并對(duì)該控件進(jìn)行操作
在做動(dòng)態(tài)獲取控件時(shí),時(shí)常需要根據(jù)Id得到控件,并對(duì)該控件進(jìn)行操作,示例如下,大家可以參考下2014-06-06
.net實(shí)現(xiàn)webservice簡(jiǎn)單實(shí)例分享
這篇文章主要介紹了.net實(shí)現(xiàn)webservice簡(jiǎn)單實(shí)例,需要的朋友可以參考下2014-04-04
.NET獲取枚舉DescriptionAttribute描述信息性能改進(jìn)的多種方法
這篇文章主要介紹了.NET獲取枚舉DescriptionAttribute描述信息性能改進(jìn)的多種方法 的相關(guān)資料,需要的朋友可以參考下2016-01-01

