javascript - 如何动态获取函数参数名称/值?

标签 javascript reflection function-parameter

有没有办法动态获取函数的函数参数名称?

假设我的函数如下所示:

function doSomething(param1, param2, .... paramN){
   // fill an array with the parameter name and value
   // some other code 
}

现在,我如何从函数内部将参数名称及其值的列表放入数组中?

最佳答案

以下函数将返回传入的任何函数的参数名称数组。

var STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
var ARGUMENT_NAMES = /([^\s,]+)/g;
function getParamNames(func) {
  var fnStr = func.toString().replace(STRIP_COMMENTS, '');
  var result = fnStr.slice(fnStr.indexOf('(')+1, fnStr.indexOf(')')).match(ARGUMENT_NAMES);
  if(result === null)
     result = [];
  return result;
}

示例用法:

getParamNames(getParamNames) // returns ['func']
getParamNames(function (a,b,c,d){}) // returns ['a','b','c','d']
getParamNames(function (a,/*b,c,*/d){}) // returns ['a','d']
getParamNames(function (){}) // returns []

编辑:

随着 ES6 的发明,这个函数可以被默认参数触发。这是一个在大多数情况下应该有效的快速技巧:

var STRIP_COMMENTS = /(\/\/.*$)|(\/\*[\s\S]*?\*\/)|(\s*=[^,\)]*(('(?:\\'|[^'\r\n])*')|("(?:\\"|[^"\r\n])*"))|(\s*=[^,\)]*))/mg;

我说大多数情况是因为有些事情会绊倒它

function (a=4*(5/3), b) {} // returns ['a']

编辑: 我还注意到 vikasde 也需要数组中的参数值。这已经在名为 arguments 的局部变量中提供。

摘自https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions_and_function_scope/arguments :

参数对象不是数组。它类似于 Array,但除了长度之外没有任何 Array 属性。例如,它没有 pop 方法。但是它可以转换为一个真正的数组:

var args = Array.prototype.slice.call(arguments);

如果 Array 泛型可用,则可以使用以下替代:

var args = Array.slice(arguments);

关于javascript - 如何动态获取函数参数名称/值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1007981/

相关文章:

javascript - 有没有办法从项目中删除所有突变观察者而不引用它?

java - 检索类中带注释的具体方法

c++ - 当一个函数有一个特定大小的数组参数时,为什么用指针替换它?

c - 为什么这个double类型变量作为函数参数传递时默认为int?

c++ - 尝试使用二维数组

javascript - 如何更改动画宽度属性以转换比例

javascript - 如何使 ember 组件从服务器获取数据。将 AJAX 调用放在组件内部似乎不是处理此问题的好习惯

c# - 如何在 .NET 中的运行时检测类的存在?

go - 将反射值转换到 golang 中?

javascript - Meteor.methods 与 ZeroMQ REQ/REP 从不返回答案