禁用数据网格模板列中的链接按钮

本文关键字:链接 按钮 数据 数据网 网格 | 更新日期: 2023-09-27 17:56:35

我正在使用Visual Studio 2008和.NET Framework 3.5。我有一个在模板列中带有链接按钮的数据网格。我正在尝试弄清楚如何在单击链接按钮后禁用单击该功能。我的 DataGrid 有 6 列,其中 LinkButton 列显示年份,其他列显示这些年份的年终数据。单击某一年时,DataGrid 会按月显示该年数据的细分。当 DataGrid 显示逐月细分时,我仍然需要年份列可见,但无法单击。我还有一个按钮和一个图表,默认情况下可见性设置为 false,但在选择一年后,可见性设置为 true,该按钮能够逐月关闭细分并返回年终细分。除了禁用链接按钮之外,我一切正常。

以下是我的 DataGrid 的 TemplateColumn 的代码:

<asp:TemplateColumn HeaderText="Year End">
    <ItemTemplate>
        <asp:LinkButton runat="server" ID="lbYear" Text='<%# DataBinder.Eval(Container, "DataItem.year") %>'></asp:LinkButton>
    </ItemTemplate>
</asp:TemplateColumn>

我尝试了以下方法:

使用代码隐藏尝试 1

protected void Page_Load(object sender, EventArgs e)
{
    LinkButton lb = ((LinkButton) FindControl("lbYear"));
    lb.Attributes.Add("onClick", "return false;");
}

尝试 2 使用 Javascript:

function disableLinkButton() {
    var lb = document.getElementById("lbYear");
    if (lb.disabled != true) { lb.disabled = true; return true; }
    }
    else { return false; }
}
<asp:TemplateColumn HeaderText="Year End">
    <ItemTemplate>
        <asp:LinkButton runat="server" ID="lbYear" OnClientClick="disableLinkButton()" Text='<%# DataBinder.Eval(Container, "DataItem.year") %>'></asp:LinkButton>
    </ItemTemplate>
</asp:TemplateColumn>

- 第三次尝试很接近,它确实使链接按钮变灰,但没有禁用单击它们的功能使用"已启用"属性尝试 3

<asp:TemplateColumn HeaderText="Year End">
    <ItemTemplate>
        <asp:LinkButton runat="server" ID="lbYear" Enabled='<%# Convert.ToInt32(DataBinder.Eval(Container.DataItem, "year"))==1?Convert.ToBoolean("True"):Convert.ToBoolean("False") %>' Text='<%# DataBinder.Eval(Container, "DataItem.year") %>'></asp:LinkButton>
    </ItemTemplate>
</asp:TemplateColumn>

我的其他一些想法包括使用"OnClick"事件或"CommandArgument"。我尝试使用"OnClick",并在后面的代码中简单地使用:

LinkButton lb = ((LinkButton) FindControl("lbYear");
lb.Enabled = false;

任何帮助,想法,想法,示例等将不胜感激。提前谢谢大家!

调整后的代码:

<ItemTemplate>
    <asp:LinkButton ID="lbYear" runat="server" OnClick="testClick" Text='<%# DataBinder.Eval(Container, "DataItem.year") %>'></asp:LinkButton>
    <a id="MyContrl_lbYear" href="javascript:__doPostBack('MyContrl$lbYear','')" onclick="this.href='#';this.disabled=true;__doPostBack('MyContrl$lbYear','');"></a>
</ItemTemplate>
protected void showChart(object sender, EventArgs e)
{
    LinkButton lbYear = ((LinkButton)FindControl("lbYear"));
    lbYear.Attributes.Add("onclick", "this.href='#';this.disabled=true;" + Page.ClientScript.GetPostBackEventReference(lbYear, "").ToString());
}

禁用数据网格模板列中的链接按钮

选项 3 和您的最后一种方法似乎是要走的路。LinkButtons的问题在于,即使将"启用"放在false上,您也不会阻止它们回发。请参阅:http://weblogs.asp.net/jeffwids/archive/2011/02/14/how-to-disable-an-asp-net-linkbutton-when-clicked.aspx

因此,您必须手动执行此操作:

lb.Attributes.Add("onclick", "this.href='#';this.disabled=true;" + Page.ClientScript.GetPostBackEventReference(lb, "").ToString());

Polity,非常感谢您的帮助,我真的很感激。不过,我找到了解决此问题的不同方法。

.ASPX 代码:

<TemplateColumn>
    <ItemTemplate>
        <asp:LinkButton runat="server" OnClick="test" Text='<%# DataBinder.Eval(Container, "DataItem.year") %></asp:LinkButton>
    </ItemTemplate>
</TemplateColumn>

.ASPX.CS代码:

protected void test(object sender, EventArgs e)
{
    foreach(var y in myDataGrid.Items)
    {
        LinkButton lb = ((y as TableRow).Cells[1].Controls[1] as LinkButton);
        lb.Enabled = false;
    }
}