javascript - 在扩展函数中使用 magic e

标签 javascript dom-events

我有一个基本的 Drop 事件处理程序,如下所示:

function Drop(e){
    e.preventDefault();
    var data=e.dataTransfer.getData("Text");
    var child = $('[target_id="'+data+'"]').get(0);
    e.target.appendChild(child);
}
function DropHandler(){}
DropHandler.prototype={
        ...
    Drop : Drop
}

创建一个新对象并扩展基本的放置处理程序:

function AdminDropHandler(){}
//Extend the DropHandler
extend(AdminDropHandler,DropHandler);
//Override Drop method in AdminDropHandler
AdminDropHandler.prototype.Drop=function(){
    DropHandler.prototype.Drop.apply(this,arguments);
    var parent_id = e.target.id;// not defined error
    ...
}

它可以扩展DropHandler的功能,但我使用的e似乎丢失了。如何解决这个问题?

最佳答案

您还没有在函数中的任何地方定义e。尝试定义它:

AdminDropHandler.prototype.Drop = function(e) {
    DropHandler.prototype.Drop.apply(this, arguments);
    var parent_id = e.target.id; // should work now
};

您也可以这样做,但不建议这样做,因为形式参数可以完成这项工作 很好:

AdminDropHandler.prototype.Drop = function() {
    var e = arguments[0];
    DropHandler.prototype.Drop.apply(this, arguments);
    var parent_id = e.target.id; // should work now
};

关于javascript - 在扩展函数中使用 magic e,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11684348/

相关文章:

javascript - jQuery - 重现序列化()

javascript - 搬运工词干算法 Javascript,如何

javascript - IE10 MSPointerUp 在不释放手指的情况下触发(触摸保持时)

javascript - 当 indexedDB 条目在其他选项卡中更改时收到通知

javascript - onClick 事件在 React redux ToDoList 应用程序中未触发

javascript - 当用户转到下一个元素时如何验证表单?

javascript - 在 Chrome 中强制全屏

javascript - Selenium Webdriver Java 无法处理 javascript :void(0), 打开新标签

javascript - 如何在 meteor/javascript 中禁用 html 元素上的鼠标单击事件

javascript - 在 Javascript 中的 iFrame 中触发滚动事件的问题