关于Javascript函数的一些思考(一)

对于我这类从传统C/C++语言开发转到`javascript语言的开发者。一定会对其灵活程度、易用性质感到惊叹。javascript里万物皆对象,而函数又是其中重中之重。这里总结下最近对函数的一些思考。
  • 1 获取函数名

javascript 是一门支持函数式编程的语言,函数可以作为参数传递,也可以作为返回值返回给调用者。每个函数对象都有一个name属性得到当前函数的名称,如果是匿名函数则返回空字符。

var func = function test() {};
console.log(func.name);//test

var func2 = function() {};
console.log(func.name);//''

  • 2 获取实参

javascript函数调用的时候实参数都被放到了一个arguments类数组对象中。为什么说它是类数组对象呢?因为它是一个对象,只不过这个对象在使用的过程中可以被遍历数组一样遍历,从而它得到实参。

function show(a, b, c) {
    console.log(arguments.length);//2
    for(var i = 0; i < arguments.length; i++) {
        console.log(arguments[i]);// 1, 2
    }
}
show(1, 2);
  • 3 获取形参个数、名称

形参个数:

var func = function(a, b, c) {
    console.log(arguments.callee.length)
};
console.log(func.length);

arguments.callee表示当前函数本身

形参名称:

    var func = function(a, b, c) {};
    var params = /\(\s*([\s\S]*?)\s*\)/.exec(func);

解释一下上面的正则表达式:

由于形参都是包括在function关键字后第一对括号内,所以我们首先需要定位到该括号,需要考虑参数之间的空格数量。中间花括号表示匹配任意字符(为什么不直接用.呢?因为.不包括换行符号)。

为什么可以直接把一个函数对象传入exec?

原因很简单, exec会判断当前参数类型,如果不是string,则调用该参数的toString函数。

既然知道了原理,还可以怎么写呢?

    var func = function(a, b, c) {};
    var str = func.toString();
    var params = str.slice(str.indexOf('(')+1, str.indexOf(')')).split(/\s*,\s*/);
    //或者
    var params2 = str.split(')')[0].split('(')[1].split(/\s*,\s*/);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值