Имя команды и аргумент команды не работают с J-Query Quick Search в Gridview - PullRequest
0 голосов
/ 20 января 2020

Я реализовал Быстрый поиск, используя jquery в gridview для столбцов. Работает нормально, но имя команды и аргумент команды для количества действий (кнопка) не работают. когда я пытаюсь получить значение столбца при нажатии кнопки, то это показывает, что входная строка была не в правильном формате. и еще одна проблема - когда я не использую аргумент команды, он заменяет первую строку. Пожалуйста, ознакомьтесь с кодом для справки. Когда изображение аргумента Command Argument также не используется: -

Если я удаляю событие GridView1_DataBound, значит, оно работает нормально, и я хочу, чтобы событие GridView1_DataBound выполняло быстрый поиск.

<asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" BackColor="#CCCCCC"
                                    BorderColor="#999999" BorderStyle="Solid" BorderWidth="3px" CssClass="footable table table-bordered table-responsive"
                                    CellPadding="4" CellSpacing="2" ForeColor="Black" OnRowCommand="GridView1_RowCommand"
                                    OnSelectedIndexChanged="GridView1_SelectedIndexChanged" ShowHeaderWhenEmpty="True"
                                    EmptyDataText="Sorry, There is no data available !" OnRowDataBound="GridView1_RowDataBound"
                                    OnDataBound="GridView1_DataBound">
                                    <Columns>                                        
                                        <asp:BoundField DataField="username" HeaderText="Username" SortExpression="username" />
                                        <asp:BoundField DataField="full_name" HeaderText="Owner Name" SortExpression="full_name" />
                                        <asp:BoundField DataField="mobile" HeaderText="Mobile No" SortExpression="mobile" />
                                        <asp:BoundField DataField="Registration_As" HeaderText="User" SortExpression="Registration_As" />
                                        <asp:BoundField DataField="Registration_Date" HeaderText="Registration Date" SortExpression="Registration_Date"
                                            DataFormatString="{0:MM-dd-yyyy hh:mm tt}" />
                                        <asp:BoundField DataField="active_status" HeaderText="STATUS" SortExpression="active_status" />
                                        <asp:TemplateField HeaderText="Action">
                                            <ItemTemplate>
                                                <asp:Button ID="btnaddcredit" runat="server" CommandName="AddCredit" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="ADD CREDIT" OnClientClick="return fnAddCredit();" CssClass="btn btn-success btn-xs" />
                                                <asp:Button ID="btnSetCommision" runat="server" CommandName="SetCommision" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="SET COMMISSION" OnClientClick="return  fnSetCommision();" CssClass="btn btn-complete btn-xs" />
                                                <asp:Button ID="btnRemoveCredit" runat="server" CommandName="RemoveCredit" Text="REMOVE CREDIT"
                                                    OnClientClick="return fnRemoveCredit();" CssClass="btn btn-info btn-xs" />
                                                <asp:Button ID="btnResetpass" runat="server" CommandName="ResetPass" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="RESET PASS" OnClientClick="return fnResetPass();" CssClass="btn btn-warning btn-xs" />
                                                <asp:Button ID="btnResetPin" runat="server" CommandName="ResetPin" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="RESET PIN" OnClientClick="return fnResetPin();" CssClass="btn btn-warning btn-xs" />
                                                <asp:Button ID="btnUpdate" runat="server" CommandName="Updatede" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="UPDATE" CssClass="btn btn-primary btn-xs" />
                                                <asp:Button ID="btnDelete" runat="server" CommandName="Deletede" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="DELETE" OnClientClick="return fnConfirmDelete();" CssClass="btn btn-danger btn-xs" />
                                                <asp:Button ID="btnActivate" runat="server" CommandName="ActivateDe" CommandArgument="<%# ((GridViewRow) Container).RowIndex %>"
                                                    Text="ACTIVATE/DEACTIVATE" OnClientClick="return fnConfirmDeactivate();" CssClass="btn btn-default btn-xs" />
                                            </ItemTemplate>
                                        </asp:TemplateField>
                                    </Columns>
                                    <FooterStyle BackColor="#CCCCCC" />
                                    <HeaderStyle BackColor="Black" Font-Bold="True" ForeColor="White" />
                                    <PagerStyle BackColor="#CCCCCC" ForeColor="Black" HorizontalAlign="Left" />
                                    <RowStyle BackColor="White" />
                                    <SelectedRowStyle BackColor="#000099" Font-Bold="True" ForeColor="White" />
                                    <SortedAscendingCellStyle BackColor="#F1F1F1" />
                                    <SortedAscendingHeaderStyle BackColor="#808080" />
                                    <SortedDescendingCellStyle BackColor="#CAC9C9" />
                                    <SortedDescendingHeaderStyle BackColor="#383838" />
                                </asp:GridView>

Также см. Скрипт JS

<script type="text/javascript">
        $(function () {
            $('.search_textbox').each(function (i) {
                $(this).quicksearch("[id*=ContentPlaceHolder1_GridView1] tr:not(:has(th))", {
                    'testQuery': function (query, txt, row) {
                        return $(row).children(":eq(" + i + ")").text().toLowerCase().indexOf(query[0].toLowerCase()) != -1;
                    }
                });
            });
        });
    </script>

Также см. Код вашей ссылки: -

protected void GridView1_DataBound(object sender, EventArgs e)
    {
        GridViewRow row = new GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Normal);
        for (int i = 0; i < GridView1.Columns.Count; i++)
        {
            TableHeaderCell cell = new TableHeaderCell();
            TextBox txtSearch = new TextBox();
            txtSearch.Attributes["placeholder"] = GridView1.Columns[i].HeaderText;
            txtSearch.CssClass = "search_textbox";
            if (GridView1.Columns[i].HeaderText != "Action")
            {
                cell.Controls.Add(txtSearch);
            }
            row.Controls.Add(cell);
        }
        GridView1.HeaderRow.Parent.Controls.AddAt(1, row);
    }

protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        int index = 0;
        GridViewRow row;
        GridView grid = sender as GridView;
        switch (e.CommandName)
        {
            case "AddCredit":
                index = Convert.ToInt32(e.CommandArgument);
                row = grid.Rows[index];
                Session["crow"] = row.Cells[0].Text;

                Response.Redirect("addcredit.aspx");
                break;

            case "RemoveCredit":
                ////If want to use withour Command Argument
                ////first find the button that got clicked
                var clickedButton = e.CommandSource as Button;
                ////find the row of the button
                var clickedRow = clickedButton.NamingContainer as GridViewRow;
                ////now as the UserName is in the BoundField, access it using the cell index.
                var clickedUserName = clickedRow.Cells[0].Text;
                break;
        }
    }

My Complete Gridview это как Когда не используется командный аргумент

...