javascript - 将上下文变量作为参数传递给 onclick 事件处理程序

标签 javascript onclick dom-events

*这发生在一个更大的代码块内的 for 循环中。整个循环请参阅帖子末尾。

我已经阅读了所有似乎与此主题相关的帖子,但我仍然迷失方向。

我正在尝试将 onclick 事件分配给复选框。分配给 onclick 事件的函数需要访问定义复选框的范围内可用的变量 (idvariable)。

var idvariable = parentChildList[i].children[j]["subjectid"];
var input = document.createElement("input");
input.type = "checkbox";
input.value = "";
input.onclick = function () {
   return clicked(idvariable);
};

function clicked(id) {
   alert(id); 
};

我已经尝试了内联函数和命名函数的每种变体,但我不知道如何让单击的函数访问idvariable。在上面的示例中,该变量的值未定义。

或者,如果我用这种方式尝试:

var input = document.createElement("input");
input.type = "checkbox";
input.value = "";

var idvariable = parentChildList[i].children[j]["subjectid"];
input.onclick = function (idvariable) {
  return clicked(idvariable);
};

function clicked(id) {
   alert(id); 
};

我收到一条警告,内容为[object MouseEvent]。与以下相同,我从分配给 onclick 事件的方法名称中删除了 ():

var idvariable = parentChildList[i].children[j]["subjectid"];
input.onclick = function () {
   return clicked;
}(idvariable);

function clicked(id) {
   return alert(id); 
};

*整个循环:

    for (var i = 0; i < parentChildList.length; i++) {
        var row = table1.insertRow(-1);
        var cell = row.insertCell(0);
        cell.innerHTML =
            "<h4 class=\"panel-title\"><a data-toggle=\"collapse\" data-parent=\"#accordion\" href=\"#collapse" + i + "\">" + parentChildList[i]["title"] + "</a></h4>";

        if (parentChildList[i].children.length > 0) {
            var row2 = table1.insertRow(-1);
            var cell2 = row2.insertCell(0);

            var table2 = document.createElement("table");
            table2.className = "collapse";
            table2.id = "collapse" + i;
            cell2.appendChild(table2); 

            for (var j = 0; j < parentChildList[i].children.length; j++) {
                var row3 = table2.insertRow(-1);
                var cell3 = row3.insertCell(0);
                var div = document.createElement("div");
                div.className = "checkbox";

                var label = document.createElement("label");
                label.innerText = parentChildList[i].children[j]["title"];

                var input = document.createElement("input");
                input.type = "checkbox";
                input.value = "";
                input.setAttribute('subj', idvariable);

                var idvariable = parentChildList[i].children[j]["subjectid"];
                alert(idvariable); 
                input.onclick = function () {
                    return clicked(this.getAttribute('subj'));
                };

                function clicked(id) {
                    return alert(id); 
                };

                cell3.style.padding = "0px 0px 0px 10px";
                cell3.style.fontsize = "x-small";

                cell3.appendChild(div);
                div.appendChild(label);
                label.insertBefore(input, label.childNodes[0]);
            }
        }
    }

最佳答案

onclick 处理程序接收 Event 对象。如果处理程序以 elem.onclick=handler 形式附加,则该元素在处理程序内可用 this 形式使用。所以这是解决方法。

var idvariable = parentChildList[i].children[j]["subjectid"];
var input = document.createElement("input");
input.type = "checkbox";
input.value = "";
input.setAttribute('data-subj', idvariable); 
input.onclick = function () {
   return clicked(this.getAttribute('data-subj'));
};

function clicked(id) {
   alert(id); 
};

关于javascript - 将上下文变量作为参数传递给 onclick 事件处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37219345/

相关文章:

javascript - document.readyState 在 Firefox 和 Chrome 中不起作用

javascript - 如何以编程方式触发 ionic 中的双击事件?

javascript - 使用 jQuery.getScript 导入多个文件

javascript - angularJS 中的客户端重复数据验证

javascript - 向原型(prototype)添加功能

javascript - 选择链接(内部或外部)时如何关闭模式对话框以及如何设置一个或多个异常(exception)?

Javascript:在类内分配onclick

javascript - Onclick 与 Onsubmit 问题(真/假和警报行为?)

javascript - 在 Backbone View 中触发 el 事件

javascript - 如何测试 util.inherits() 的原型(prototype)继承?