js 传递方法

简介:

js 中可以把函数(方法)当做参数传递:

Js代码   收藏代码
  1. <script type="text/javascript">  
  2.        var A= function (args2) {  
  3.            console.log('A start....');  
  4.            console.log('argument:\t'+args2);  
  5.            console.log('A end.');  
  6.        };  
  7.        var B= function (fn2, context) {  
  8.            console.log('B start,,,,');  
  9.            var arg22='参数';  
  10.            fn2.call(context,arg22);  
  11.            console.log('B end,');  
  12.        };  
  13.    </script>  

 上面时函数声明,下面是函数调用:

Js代码   收藏代码
  1. <script type="text/javascript">  
  2.     B(A);  
  3. </script>  

 把函数A 作为参数传递给B.

执行结果:

 

执行序列如下:

 

还有一种方式:

Js代码   收藏代码
  1. var A= function (args2) {  
  2.             console.log('A start....');  
  3.             console.log('argument:\t'+args2);  
  4.             console.log('A end.');  
  5.         };  
  6.         var B= function (fn2, context) {  
  7.             console.log('B start,,,,');  
  8.             var arg22='参数';  
  9.             fn2(arg22);  
  10.             console.log('B end,');  
  11.         };  

 执行结果相同.

 

类似的函数调用函数的例子:

Js代码   收藏代码
  1. if (evtType == 'focus' && settings.focus_callback && typeof settings.focus_callback === 'function') {  
  2.                     e = e || window.event || arguments.callee.caller.arguments[0];  
  3.                     settings.focus_callback(e);  
  4.                 }  

 

 

那么Java中可以把函数当做参数传递吗?

不行!!!

那么java中可以当做参数传递的有哪些呢?

(1)数据类型,比如int,String,List

(2)自定义对象,比如Student,Person,School等

 

那么有时候真的需要把方法当做参数传递,例如:

(1)监听界面用户操作,比如监听用户点击事件,需要给这个监听器传递一个回调方法X,即监听到用户点击之后就执行方法X

(2)代理,比如有个代理,需要传入两个函数,分别在代理实际方法前后执行

 

Java代码   收藏代码
  1. public class Main {  
  2.     public void B(A a){  
  3.         System.out.println("B start,,,,");  
  4.         String arg22="参数";  
  5.         a.callback(arg22);  
  6.         System.out.println("B end,");  
  7.     }  
  8.       
  9.     public static void main(String[] args) {  
  10.         new Main().B(new A());  
  11.           
  12.     }  
  13. }  
  14.   
  15. class A{  
  16.     public void callback(String args2){  
  17.         System.out.println("A start....");  
  18.         System.out.println("argument:\t"+args2);  
  19.         System.out.println("A end.");  
  20.     }  
  21. }  

 

相当于方法B 调用了方法callback.

进一步优化:

Java代码   收藏代码
  1. package com;  
  2.   
  3. public class Main {  
  4.     public void B(A a){  
  5.         System.out.println("B start,,,,");  
  6.         String arg22="参数";  
  7.         a.callback(arg22);  
  8.         System.out.println("B end,");  
  9.     }  
  10.       
  11.     public static void main(String[] args) {  
  12.         new Main().B(new A(){  
  13.             public void callback(String args2){  
  14.                 System.out.println("A start....");  
  15.                 System.out.println("argument:\t"+args2);  
  16.                 System.out.println("A end.");  
  17.             }  
  18.         });  
  19.           
  20.     }  
  21. }  
  22.   
  23. interface A{  
  24.     public void callback(String args2);  
  25. }  

 是不是很像事件监听器呢?

Java代码   收藏代码
  1. qrComboBox.addItemListener(new ItemListener()  
  2.         {  
  3.             @Override  
  4.             public void itemStateChanged(ItemEvent arg0)  
  5.             {  
  6.                 String  selectedPic=(String)qrComboBox.getSelectedItem();  
  7.                 if(!ValueWidget.isNullOrEmpty(selectedPic)){  
  8.                     inputQRTextArea.setText(selectedPic);  
  9.                     generateQRAction(false);  
  10.                     System.out.println("addItemListener");  
  11.                 }  
  12.             }  
  13.         });  

 

 

相关文章
|
2月前
|
JavaScript 前端开发 程序员
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
|
2月前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
3月前
|
缓存 监控 前端开发
JavaScript 实现大文件上传的方法
【10月更文挑战第17天】通过以上步骤和方法,我们可以实现较为可靠和高效的大文件上传功能。当然,具体的实现方式还需要根据实际的应用场景和服务器要求进行调整和优化。
|
4天前
|
JavaScript 前端开发 开发者
JavaScript字符串的常用方法
在JavaScript中,字符串处理是一个非常常见的任务。JavaScript提供了丰富的字符串操作方法,使开发者能够高效地处理和操作字符串。本文将详细介绍JavaScript字符串的常用方法,并提供示例代码以便更好地理解和应用这些方法。
34 13
|
2月前
|
监控 JavaScript Java
Node.js中内存泄漏的检测方法
检测内存泄漏需要综合运用多种方法,并结合实际的应用场景和代码特点进行分析。及时发现和解决内存泄漏问题,可以提高应用的稳定性和性能,避免潜在的风险和故障。同时,不断学习和掌握内存管理的知识,也是有效预防内存泄漏的重要途径。
172 52
|
2月前
|
JavaScript 前端开发 索引
js中DOM的基础方法
【10月更文挑战第31天】这些DOM基础方法是操作网页文档结构和实现交互效果的重要工具,通过它们可以动态地改变页面的内容、样式和行为,为用户提供丰富的交互体验。
|
2月前
|
缓存 JavaScript UED
js中BOM中的方法
【10月更文挑战第31天】
|
2月前
|
缓存 JavaScript 前端开发
JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用
本文深入讲解了 JavaScript 与 DOM 交互的基础及进阶技巧,涵盖 DOM 获取、修改、创建、删除元素的方法,事件处理,性能优化及与其他前端技术的结合,助你构建动态交互的网页应用。
61 5
|
2月前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
34 1
|
2月前
|
JavaScript 前端开发
.js方法参数argument
【10月更文挑战第26天】`arguments` 对象为JavaScript函数提供了一种灵活处理参数的方式,能够满足各种不同的参数传递和处理需求,在实际开发中具有广泛的应用价值。
51 7