jQuery与document.on取消绑定?

问题描述 投票:0回答:1

我的按钮发射两次。其他SO帖子说要解除文档中的点击功能。问题是HTML元素被动态地附加到文档,所以我需要调用:

$(document).on("click", "#id", function())

但是如何从document.on语句中“解除绑定”click函数?

这是我的完整代码:

//Add Column
$(document).on("click", ".btn-add-tbl-col", addColumn); 

function addColumn() {

    console.log("addColumn fired!");  //Console shows this statement twice when I click the button once

    //Identify the table into cache
    var $tbl = $("#main-tbl-sch-tbl");

    //Count the number of records
    var rows = $tbl.find("tr.record").length;

    var columns = $tbl.find("th.tbl-column").length;
    columns++;

    var newCol = "<th class='tbl-column' data-id='0'>*Click*</th>";
    $(newCol).insertBefore($tbl.find("th.no-click-last"));

    $tbl.children("tbody.tbody-records").children("tr").each(function () {
            var $td = '<td class="record-cell" data-id="0" data-isstatic="1" data-col="' + columns + '" data-row="' + rows + '" data-colID="0" data-rowID="0" data-asid="0" data-deid="0" data-isnull="1" data-nameid="0" data-tbllookupid="0" data-collookupid="0" data-munterspn="0">*Click*</td>';
            $(this).append($td);
    });

    var newTableWidth = parseFloat((167 * columns) + 33 + 33);
    $tbl.css("width", newTableWidth.toString() + "px");
}

仅供参考:没有其他点击功能绑定到班级

jquery dom unbind
1个回答
1
投票

您可以使用与绑定相同的方式取消绑定事件,但使用off()方法。

http://api.jquery.com/off/

因此,根据您需要的文档:

$(document).off('click', '#id').on("click", "#id", function())

在您确切的问题中,您需要:

$(document).off("click", ".btn-add-tbl-col").on("click", ".btn-add-tbl-col", addColumn);

© www.soinside.com 2019 - 2024. All rights reserved.