创建按钮OnClientClick asp net

时间:2017-12-04 09:33:55

标签: javascript c# asp.net button onclientclick

我正在从代码c#创建按钮:

        Button btnAddCalculation = new Button();
        btnAddCalculation.ID = "btnAddCalculation";
        btnAddCalculation.Text = "Add count";
        btnAddCalculation.SkinID = "middleButton";
        btnAddCalculation.Visible = true;

        string sPath = String.Format(
            "WindowCalculationArenda.aspx?{0}={1}&TempGuid={2}&IdDocument={3}",
            SessionViewstateConstants.CalculationType,
            CalcType.New,
            Guid.NewGuid(),
            oEditedDocument.Id.ToString()
        );
        //          btnAddCalculation.Attributes.Add("onclick", @"window.open('InformationAboutAddAddr.aspx', '_blank', 'location=yes,height=500,width=450,scrollbars=yes,status=yes');");
        btnAddCalculation.Click += new EventHandler(btnClick_cl);
        btnAddCalculation.OnClientClick = clsCommonHelper.sGetWindowOpen(sPath, 1100, 500) + "return false;";

    public static string sGetWindowOpen(string sLink, int iWidth, int iHeight)
    {
        return "javascript:setTimeout(function(){ WindowOpen('" + sLink + "', " + iWidth + ", " + iHeight + "); }, 100); ";
    }

但是在客户端,当我点击时,OnClientClick功能不起作用 什么都没发生。我做错了什么???

生成的HTML:

<input type="submit" name="ctl00$ctl00$Main$EditorMain$tabTabContainer$ctl00$Attr‌​433$btnAddCalculatio‌​n"  
value="Add count" 
id="ctl00_ctl00_Main_EditorMain_tabTabContainer_ctl00_Attr43‌​3_btnAddCalculation"  
disabled="disabled" class="blue_button" />

3 个答案:

答案 0 :(得分:1)

禁用按钮

如果将动态按钮添加到自身已禁用的容器中,则此动态按钮也将被禁用。为了确保正确添加按钮,请使用HTML中的新容器(例如<asp:PlaceHolder>)并从代码隐藏向该容器添加按钮。

还可以查看以下内容: -

创建新按钮时,请使用CausesValidation = false。这将避免在单击此按钮时触发任何RequiredFieldValidator。 RequiredFieldValidator也会停止单击按钮。 e.g。

Button btnAddCalculation = new Button();
btnAddCalculation.ID = "btnAddCalculation";
btnAddCalculation.Text = "Add count";
btnAddCalculation.SkinID = "middleButton";
btnAddCalculation.Visible = true;
btnAddCalculation.Enabled = true;
btnAddCalculation.CausesValidation = false;

答案 1 :(得分:0)

解决此问题:

    Button btnAddCalculation = new Button();
    btnAddCalculation.ID = "btnAddCalculation";
    btnAddCalculation.Text = "Add count";
    btnAddCalculation.SkinID = "middleButton";
    btnAddCalculation.Visible = true;
    btnAddCalculation.Enabled = true;

    string sPath = String.Format(
        "WindowCalculationArenda.aspx?{0}={1}&TempGuid={2}&IdDocument={3}",
        SessionViewstateConstants.CalculationType,
        CalcType.New,
        Guid.NewGuid(),
        oEditedDocument.Id.ToString()
    );
    //          btnAddCalculation.Attributes.Add("onclick", @"window.open('InformationAboutAddAddr.aspx', '_blank', 'location=yes,height=500,width=450,scrollbars=yes,status=yes');");
    btnAddCalculation.Click += new EventHandler(btnClick_cl);
    btnAddCalculation.OnClientClick = clsCommonHelper.sGetWindowOpen(sPath, 1100, 500) + "return false;";

public static string sGetWindowOpen(string sLink, int iWidth, int iHeight)
{
    return "javascript:setTimeout(function(){ WindowOpen('" + sLink + "', " + iWidth + ", " + iHeight + "); }, 100); ";
}

默认情况下 asp.net服务器会将按钮设置为已停用,除非您明确指定

答案 2 :(得分:0)

您提供的ASP.NET代码看起来不错;所以我怀疑这个问题与在客户端上运行的脚本有关。也许提交按钮被禁用,因为表单内容尚未生效。在这种情况下,您的按钮可能会被禁用,具体取决于用于标识提交按钮的选择器。

要避免这种情况,请更改按钮的行为,使其呈现为button类型的输入,而不是submit。您可以使用UseSubmitBehavior - 属性来实现此目的:

btnAddCalculation.UseSubmitBehavior = false;