首页 web前端 js教程 给事件响应函数传参数的四种方式小结_javascript技巧

给事件响应函数传参数的四种方式小结_javascript技巧

May 16, 2016 pm 05:10 PM
函数参数

如何给事件handler传参数?在刚刚接触Javascript的时候,由于对闭包理解不深刻,常常纠结于该问题。

在讨论群里也经常碰到这样的问题,如下

复制代码 代码如下:




   
    如何给事件handler传参数?


 Click me
 



如何把参数v1,v2传给handler?默认事件对象将作为handler的第一个参数传入,这时点击链接第一个弹出的是事件对象,第二个是undefined。

方案一 ,未保留事件对象作为第一个参数传入

复制代码 代码如下:

function handler(arg1,arg2){
 alert(arg1);
 alert(arg2);
}
E.on(document.getElementById('aa'),'click',function(){ 
 handler(arg1,arg2); 
});

方案二,保留事件对象作为第一个参数 
复制代码 代码如下:

function handler(e,arg1,arg2){
 alert(e);
 alert(arg1);
 alert(arg2);
}
E.on(document.getElementById('aa'),'click',function(e){
 handler(e,arg1,arg2);
});

方案三,给Function.prototype添加getCallback,不保留事件对象
复制代码 代码如下:

Function.prototype.getCallback = function(){
 var _this = this, args = arguments;  
 return function(e) {
        return _this.apply(this || window, args);
    };
}
E.on(document.getElementById('aa'),'click',handler.getCallback(v1,v2));

方案四,给Function.prototype添加getCallback,保留事件对象作为第一个参数传入
复制代码 代码如下:

Function.prototype.getCallback = function(){
 var _this = this, args = [];
 for(var i=0,l=arguments.length;i  args[i+1] = arguments[i];
 }
 return function(e) {
  args[0] = e;
        return _this.apply(this || window, args);
    };
}
E.on(document.getElementById('aa'),'click',handler.getCallback(v1,v2));
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

C++ 函数参数传递方式与线程安全的关系 C++ 函数参数传递方式与线程安全的关系 Apr 12, 2024 pm 12:09 PM

函数参数传递方式与线程安全:值传递:创建参数副本,不影响原始值,通常线程安全。引用传递:传递地址,允许修改原始值,通常不线程安全。指针传递:传递指向地址的指针,类似引用传递,通常不线程安全。在多线程程序中,应慎用引用和指针传递,并采取措施防止数据竞争。

C++ 函数参数详解:不定参数传递的实现方式与优缺点 C++ 函数参数详解:不定参数传递的实现方式与优缺点 Apr 28, 2024 am 09:48 AM

C++不定参数传递:通过...运算符实现,可接受任意数量的附加参数,优点包括灵活性、可扩展性和简化代码,缺点包括性能开销、调试困难和类型安全。常见实战案例包括printf()和std::cout,它们使用va_list处理可变数量的参数。

C++编译错误:重复定义函数参数,应该怎样解决? C++编译错误:重复定义函数参数,应该怎样解决? Aug 22, 2023 pm 12:33 PM

C++作为一种高效的编程语言,因其可靠性被广泛应用于各种各样的领域。但是,在编写代码的过程中,经常会遇到一些编译错误,其中重复定义函数参数就是其中之一。本文将详细介绍重复定义函数参数的原因和解决方案。什么是重复定义函数参数?在C++编程中,函数参数是指在函数定义和声明中出现的变量或表达式,用于接受函数调用时传递的实参。在定义函数的参数列表时,每个参数必须使用

C++ 函数参数详解:传出机制的本质与注意事项 C++ 函数参数详解:传出机制的本质与注意事项 Apr 27, 2024 pm 12:00 PM

C++函数参数传递方式有两种:传值调用(不影响实参)和传引用调用(影响实参)。传出参数通过传引用或指针实现,函数可以通过修改参数引用或指针指向的变量来传递值给调用方。使用时需要注意:传出参数必须明确声明,只能对应一个实参,不能指向函数内局部变量,传指针调用需谨慎避免野指针。

PHP 函数参数类型有哪些? PHP 函数参数类型有哪些? Apr 10, 2024 pm 04:21 PM

PHP函数参数类型包括标量类型(整数、浮点数、字符串、布尔值、空值)、复合类型(数组、对象)和特殊类型(回调函数、可变参数)。函数可自动转换不同类型参数,但也可通过类型声明强制特定类型,以防止意外转换并确保参数正确性。

数组可以用作函数参数吗? 数组可以用作函数参数吗? Jun 04, 2024 pm 04:30 PM

是的,在许多编程语言中,数组可以作为函数参数,函数将对其中存储的数据执行操作。例如C++中的printArray函数可以打印数组中的元素,而Python中的printArray函数可以遍历数组并打印其元素。这些函数对数组所做的修改也会反映在调用函数中的原数组中。

如何选择 C++ 函数参数的传递方式? 如何选择 C++ 函数参数的传递方式? Apr 12, 2024 am 11:45 AM

在C++中选择函数参数传递方式时,有四种选择:按值传递、按引用传递、按指针传递和按const引用传递。按值传递创建参数值的副本,不会影响原始参数;按引用传递参数值的引用,可以修改原始参数;按指针传递参数值的指针,允许通过指针修改原始参数值;按const引用传递参数值的const引用,只能访问参数值,不能修改。

C++ 函数参数传递方式与模板元编程的关系 C++ 函数参数传递方式与模板元编程的关系 Apr 12, 2024 pm 01:21 PM

函数参数传递方式与模板元编程的关系:值传递:复制参数值,函数无法修改原始变量。引用传递:传递对参数的引用,函数可修改原始变量。指针传递:传递指向参数的指针,函数可通过解引用指针修改原始变量。模板元编程可以根据参数类型生成不同的代码,通过指定参数传递方式。

See all articles