Javascript hasOwnProperty 在 Event 对象上始终为 false?

kin*_*man 6 javascript events clone hasownproperty

我希望有人可以帮助澄清与事件对象相关的 hasOwnProperty() 方法。

我正在尝试克隆鼠标事件(最终此对象将传递给 iframe) 我已经构建了一个“克隆”函数 - 但是每当我尝试克隆窗口事件(即滚动、单击等)时,“hasOwnProperty”的所有实例()' 返回假。例如,我遍历对象 - 使用 hasOwnProperty() 进行检查 - 每个属性都返回 false。这适用于标准对象 - 但不适用于事件对象。

这是因为事件对象中的所有属性都是继承的吗?还是代码有问题?

任何启示将不胜感激:)

代码片段:

function cloneObject (o_node) {
 var newObject = {};

  for (var child_node in o_node) {

    if (o_node.hasOwnProperty(child_node)) {
    //no object properties are returning true at this point. 

    newObject[child_node] = o_node[child_node];

    }else{
    console.log("!hasOwnProperty()");
    }
  }
 return newNode;
}

function onclick(e){

   var cloned_object_e = cloneObject(e); //returns an empty object;

}

window.addEventListener('click', onclick);
Run Code Online (Sandbox Code Playgroud)

geo*_*org 4

您的假设是正确的 -e参数是一个空心new MouseEvent对象,没有自己的属性,只有从原型链继承的属性MouseEvent<-UIEvent<-Event。继承图如下:

在此输入图像描述