Как отправить несколько командных аргументов через командную кнопку? (RowCommand Event) - PullRequest
4 голосов
/ 04 августа 2011

Я пытаюсь отправить через несколько аргументов команды, когда вызывается команда строки:

                <asp:TemplateField HeaderText="Status">
                    <ItemTemplate>
                        <asp:Button ID="btnAct" runat="server" CausesValidation="False" CommandName="Action"
                            Text='De-Activate' CommandArgument='<%# Bind("isActiveYN") + ";" + Bind("employeeid") %>' />                           



                        <asp:Label ID="lblActivate" runat="server" Text='<%# Bind("isActiveYN") %>' Visible='False'></asp:Label>
                    </ItemTemplate>
                </asp:TemplateField>

Как бы то ни было, когда я использую более одного аргумента, он показывает только вторую половину, в этом employeeid. Если я указываю только один аргумент, он отлично работает.

protected void gvEmp_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        string changeactive = null;

        if (e.CommandName == "Action")
        {
            //LinkButton lnkPortal = (LinkButton)sender;
            string isactivestatus = Convert.ToString(e.CommandArgument);

            string[] arg = new string[2];

            arg = isactivestatus.Split(';');
            //lblTest.Text = isavtivestatus.Text;
            string status = Convert.ToString(arg[0]);
            int empid = Convert.ToInt32(arg[1]);

            if (status.ToUpper() == "Y")
            {
                lblTest.Text = isactivestatus + " Will Change to N  " ;
                changeactive = "N";
            }
            else if (arg[0].ToUpper() == "N")
            {
                lblTest.Text = isactivestatus + " Will Change to Y  " ;
                changeactive = "Y";
            }

            DataSet ds = new DataSet("Employees");

            string query = "Update employees set isActiveYN='" + changeactive 
                            + "' where employeeid=" + empid;


            SqlConnection con = new SqlConnection("Password=admin;User ID=admin;Initial Catalog=asptest;Data Source=dbsvr");
            SqlDataAdapter da = new SqlDataAdapter(query, con);

            da.Fill(ds);
            BindGrid();
        }
    }

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

1 Ответ

9 голосов
/ 04 августа 2011

Pavitar, попробуйте -

<%# Eval("isActiveYN") + ";" + Eval("employeeid") %>

Bind - это двунаправленная привязка, которая используется для передачи измененных данных на сервер. ASP не может отделить одно значение от клиента более чем одному свойству сервера.

...