分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

js函数获取ev对象

发布时间:2023-09-06 02:24责任编辑:顾先生关键词:js

今天工作中遇到一个问题,就是平时获取一个ev(event)对象时候一般直接在调用方法里面写一个ev参数,即可直接拿到这个对象,但是有时候会遇到函数调用不是直接加在一个dom对象的后面,如:

var oDiv = document.getElementById(‘box‘);

oDiv.onclick = function(ev) {

var x = ev.pageX;

...

};

而是写在函数属性中,如:

var oDiv = document.getElementById(‘box‘);

oDiv.setAttribute(‘onclick‘,‘fn()‘);

function fn() {

};

这个时候是无法直接在函数里面传参的,只能通过如下方式获取该对象

function fn() {

var ev = arguments.callee.caller.arguments[0];

1.当函数被调用时,它的arguments.callee对象就会指向自身,也就是一个对自己的引用。
由于arguments在函数被调用时才有效,因此arguments.callee在函数未调用时是不存在的(即null.callee),且解引用它会产生异常。

2.在一个函数调用另一个函数时,被调用函数会自动生成一个caller属性,指向调用它的函数对象。如果该函数当前未被调用,或并非被其他函数调用,则caller为null。

};

js函数获取ev对象

原文地址:https://www.cnblogs.com/shenwh/p/10041452.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved