首页 > 函数名外加上 [ ] 是什么意思?

函数名外加上 [ ] 是什么意思?

比如:

function foo(){

   }
   alert([foo][0] === foo)//true

照此来看, [foo]应该是将函数包装成了一个数组, 而这个数组只有一项, 就是原函数本身.
想了解下这个用法的详细情况.
是用来解决什么问题的? 最好能举个具体的使用场景.
基本原理是什么?属于JavaScript的哪一个知识点范畴.
希望有知道的朋友不吝指教.
我也反感伸手党啦~~ 但是一直都没搜到关于这个的解释, 我也想不出其他的关键词了, 望谅解.


你已经掌握了真谛不是么,就是封装一个数组。实在没什么高深的内容了,除非你贴出在哪里、什么场景下看到的这种用法。说实在话,这种做法还真没什么“模式”可言。唯一能想到的就是或许在某些依赖数组作为输入的使用。

譬如:现在别人提供了一个函数自动执行器,她就依赖输入必须是数组,像这样:

var exec = function(funcs){
    for(var i = 0; i< funcs.length; i++){
        funcs[i]();
    }
};

以上代码纯属虚构

要是这样的话,那你不是必须把foo封装到数组里么,否则都没法用人家的exec了。

所以我的理解是,这是个按需的操作,并没有特别的深意。

欢迎高人指正,并提供深意解答


一种应用场景是,'foo'是由后端脚本生成的字符串。比如:

var func_name = [<%=func_name_by_back_end%>][0];
func_name && func_name();

func_name_by_back_end字符串为null时,func_name为undefined。
如果不使用数组,那么代码写起来更复杂一些,比如可能是这样:

var func_name = <%=func_name_by_back_end?func_name_by_back_end:"undefined"%>;
func_name && func_name();

不过这种方式(在js里嵌入后端代码)在不是迫不得已的情况下还是不要使用的好。


简单的事情复杂化

【热门文章】
【热门文章】