加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 如何通过命令按钮发送多个命令参数?(RowCommand Eve

发布时间:2020-12-16 07:22:49 所属栏目:asp.Net 来源:网络整理
导读:我正在尝试在调用rowcommand时发送多个命令参数: asp:TemplateField HeaderText="Status" ItemTemplate asp:Button ID="btnAct" runat="server" CausesValidation="False" CommandName="Action" Text='De-Activate' CommandArgument='%# Bind("isActiveYN")
我正在尝试在调用rowcommand时发送多个命令参数:

<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();
        }
    }

请指出错误.我已经尝试过调试但无法判断出什么是错误的.

解决方法

Pavitar,尝试 –

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

绑定 – 它是用于将修改后的数据传递到服务器端的双向绑定. ASP无法将一个值从客户端分隔到多个服务器属性.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读