Подтвердить что ты не робот

__EVENTTARGET пуст после возврата кнопки

У меня есть кнопка на странице aspx

<asp:Button runat="server" CssClass="sc-ButtonHeightWidth" ID="btnFirstSave" Text="Save" OnClick="btnSave_Click" />

Я пытаюсь получить целевой объект события и источник события в коде, чтобы сделать некоторую проверку на основе этого. Я пробовал с кодом ниже.

string ctrlname = page.Request.Params.Get("__EVENTTARGET");
string ctrlname = Request.Form["__EVENTTARGET"];
string ctrlname = Request.Params["__EVENTTARGET"];

Но все вышеизложенное дает мне пустые значения. Как получить контроль, который вызвал обратную передачу каждый раз. Я делаю что-то неправильно выше?

FYI: Я уже пробовал решение, упомянутое в этой LINK. Но его единственный возвращающий текст кнопки для меня. Я хочу кнопку buttonID.

4b9b3361

Ответ 1

Я установил useubmitbehavior для false на данный момент. Хорошее решение, данное Дамитом выше в комментарии. На данный момент он отлично работает для меня без проблем. Чтобы узнать о свойстве Прочтите эту ссылку

Надеюсь, это поможет кому-то.

Ответ 2

Кнопка Asp отображается как input с типом submit, этот метод не будет заполнять _EVENTTARGET элементы управления с использованием метода "__doPostBack", чтобы вызвать обратную передачу, добавят значения в _EVENTTARGET поэтому идентификатор кнопки отсутствует в _EVENTTARGET, вы можете перебирать все элементы управления на странице, чтобы проверить, какой элемент управления вызвал обратную передачу.

Попробуйте это, чтобы захватить ваш элемент управления - Здесь

private string getPostBackControlName()
        {
            Control control = null;
            //first we will check the "__EVENTTARGET" because if post back made by       the controls
            //which used "_doPostBack" function also available in Request.Form collection.
            string ctrlname = Page.Request.Params["__EVENTTARGET"];
            if (ctrlname != null && ctrlname != String.Empty)
            {
                control = Page.FindControl(ctrlname);
            }
            // if __EVENTTARGET is null, the control is a button type and we need to
            // iterate over the form collection to find it
            else
            {
                string ctrlStr = String.Empty;
                Control c = null;
                foreach (string ctl in Page.Request.Form)
                {
                    //handle ImageButton they having an additional "quasi-property" in their Id which identifies
                    //mouse x and y coordinates
                    if (ctl.EndsWith(".x") || ctl.EndsWith(".y"))
                    {
                        ctrlStr = ctl.Substring(0, ctl.Length - 2);
                        c = Page.FindControl(ctrlStr);
                    }
                    else
                    {
                        c = Page.FindControl(ctl);
                    }
                    if (c is System.Web.UI.WebControls.Button ||
                             c is System.Web.UI.WebControls.ImageButton)
                    {
                        control = c;
                        break;
                    }
                }
            }
            return control.ID;

        }

Ответ 3

/// <summary>
/// Gets the ID of the post back control.
/// 
/// See: http://geekswithblogs.net/mahesh/archive/2006/06/27/83264.aspx
/// </summary>
/// <param name = "page">The page.</param>
/// <returns></returns>
public static string GetPostBackControlId(this Page page)
{
    if (!page.IsPostBack)
        return string.Empty;

    Control control = null;
    // first we will check the "__EVENTTARGET" because if post back made by the controls
    // which used "_doPostBack" function also available in Request.Form collection.
    string controlName = page.Request.Params["__EVENTTARGET"];
    if (!String.IsNullOrEmpty(controlName))
    {
        control = page.FindControl(controlName);
    }
    else
    {
        // if __EVENTTARGET is null, the control is a button type and we need to
        // iterate over the form collection to find it

        // ReSharper disable TooWideLocalVariableScope
        string controlId;
        Control foundControl;
        // ReSharper restore TooWideLocalVariableScope

        foreach (string ctl in page.Request.Form)
        {
            // handle ImageButton they having an additional "quasi-property" 
            // in their Id which identifies mouse x and y coordinates
            if (ctl.EndsWith(".x") || ctl.EndsWith(".y"))
            {
                controlId = ctl.Substring(0, ctl.Length - 2);
                foundControl = page.FindControl(controlId);
            }
            else
            {
                foundControl = page.FindControl(ctl);
            }

            if (!(foundControl is Button || foundControl is ImageButton)) continue;

            control = foundControl;
            break;
        }
    }

    return control == null ? String.Empty : control.ID;
}

Источник

Ответ 4

Просто добавьте UseSubmitBehavior = "False" к вашей кнопке.

<asp:Button runat="server" CssClass="sc-ButtonHeightWidth" ID="btnFirstSave" Text="Save" OnClick="btnSave_Click" UseSubmitBehavior="False" />

Ответ 5

Мое решение. Я добавляю событие OnClick, подобное этому на моей стороне клиента.

function btnClickSuper(s, e) { __doPostBack(s.name, ''); }

здесь s объект представлен моей кнопкой в ​​DevExpress, где свойство name содержит, как часть, идентификатор elment. поэтому, на стороне сервера, я могу получить идентификатор отправленной почты отправителя. Цена - это сервер OnClick enevnt не запускается.