重新加载jqGrid后,“点击”事件未触发

时间:2016-11-07 13:36:06

标签: javascript jquery asp.net-mvc jqgrid

我有一个带搜索功能的表单,当搜索信息时,会填充jqGrid。 这个jqGrid包含动态创建的按钮,这些按钮在按下时会用另一个jqGrid填充数据(与按钮所在的行相关)。

这一切都有效,当我返回搜索框并重新搜索某些不同的数据时会出现问题。 第一个jqGrid按预期加载,但是在单击嵌套按钮时,“Click”事件现在不会触发,而这反过来又不会填充下一个jqGrid。

Index.js

$('#btnSearch').click(function () {
        var hfSearchURL = '#hfSearchURL';

        //Clear all tables
        $("#tblAccounts").GridUnload();
        $("#tblContracts").GridUnload();
        $("#tblSupplies").GridUnload();

        $("#tblAccounts").jqGrid({
            url: $(hfSearchURL).val(),
            datatype: "JSON",
            mtype: "POST",
            emptyrecords: "No Accounts",
            viewrecords: true,
            multiselect: false,
            shrinkToFit: true,
            autowidth: false,
            colName: ['Account ID', 'OrganisationName', 'AuthorisedSignatory', 'BankAccountName', 'BankAccountNumber', 'Select'],
            rowNum: 25,
            postData: {
                profileID: $('#txtProfileID').val()
            },

            loadComplete: function (r) {

            },
            colModel: [
                    { name: 'Account ID', jsonmap: 'AccountID', sortable: false, width: '200', },
                    { name: 'Organisation Name', jsonmap: 'OrganisationName', sortable: false, width: '200', },
                    { name: 'Authorised Signatory', jsonmap: 'AuthorisedSignatory', sortable: false, width: '200', },
                    { name: 'Bank Account Name', jsonmap: 'BankAccountName', sortable: false, width: '200', },
                    { name: 'Bank Account Number', jsonmap: 'BankAccountNumber', sortable: false, width: '200', },

                    {
                        name: 'Select', sortable: false, width: '200',
                        formatter: function (cellvalue, options, rowObj) {
                            return '<input id="' + 'act' + rowObj.AccountID + '" value="View Contracts" type="button">';
                        }
                    }
            ],

            caption: 'Accounts'

        });

    });

    **//THIS DOES NOT FIRE WHEN RE SEARCHING**
    $("#tblAccounts").on("click", "tbody tr td input", function () {
        var hfContractsURL = '#hfContractsURL';

        $("#tblContracts").GridUnload();

        $("#tblContracts").jqGrid({
            url: $(hfContractsURL).val(),
            datatype: "JSON",
            mtype: "POST",
            emptyrecords: "No Contracts",
            viewrecords: true,
            multiselect: false,
            shrinkToFit: true,
            autowidth: false,
            colName: ['Type', 'Contract Version', 'Contract Status', 'Contract Date'],
            rowNum: 25,
            postData: {
                accountID: $(this).attr('id').replace('act', '') // use dyanmically created input id
            },

            loadComplete: function (r) {


            },
            colModel: [
                    { name: 'Type', jsonmap: 'Type', sortable: false, width: '200', },
                    { name: 'Contract Version', jsonmap: 'ContractVersion', sortable: false, width: '300', },
                    { name: 'Contract Status', jsonmap: 'ContractStatus', sortable: false, width: '200', },
                    { name: 'Contract Date', jsonmap: 'ContractDate', sortable: false, width: '200', },

                    {
                        name: 'Select', sortable: false, width: '200',
                        formatter: function (cellvalue, options, rowObj) {
                            return '<input id="' + 'cnt' + rowObj.ContractID + '" value="View Lines" type="button">';
                        }
                    }

            ],

            caption: 'Contracts'

        });

Index.cshtml

<div style="text-align: center;">
    <div style="margin-top:30px; margin-bottom: 30px; display: inline-block;">
        <table id="tblSearch">
            <tr style="background-color:grey !important">
                <td>
                    <b>Search</b>
                </td>
            </tr>
            <tr>
                <td>
                    <div>
                        <label>Profile ID</label>
                        @Html.TextBox("Search", null, new { id = "txtProfileID", onkeypress = "return event.charCode >= 48 && event.charCode <= 57" })
                        <label class="red" style="margin-left:4px; float:right; font-weight:bold; font-size:12px;" id="valIndicator"></label>
                    </div>
                </td>
            </tr>
            <tr>
                <td>
                    <div>
                        <input value="Search" type="button" id="btnSearch" style="float:right;" />
                    </div>
                </td>
            </tr>
        </table>
    </div>
</div>


<div style="text-align: center;"><div style="margin-bottom: 30px; display: inline-block;"><table id="tblAccounts"></table></div></div>
<div id="pgrAccounts"></div>
<div style="text-align: center;"><div style="margin-bottom: 30px; display: inline-block;"><table id="tblContracts"></table></div></div>
<div style="text-align: center;"><div style="margin-bottom: 30px; display: inline-block;"><table id="tblSupplies"></table></div></div>

下图显示点击按钮时应加载的jqGrid

我再次点击“搜索”按钮后检查了DOM,在重新加载网格之前,所有内容都显得相同,因此无法弄清楚为什么“点击”事件不会被触发。

1 个答案:

答案 0 :(得分:1)

我不熟悉jqgrid,但我怀疑你要附加事件的元素正在删除并重新添加。该事件未被触发,因为您附加的原始元素已不再存在。

尝试将click事件处理程序更改为以下内容:

$(document).on("click", "#tblAccounts tbody tr td input"

这会将click事件附加到文档级别而不是tblAccounts级别。