javascript – 模块模式中的函数声明与函数表达式

前端之家收集整理的这篇文章主要介绍了javascript – 模块模式中的函数声明与函数表达式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我刚刚了解了函数声明和函数表达式之间的区别.这让我想知道我是否在AngularJS代码中做得对.我正在遵循John Papa使用的模式,但现在它似乎与模块模式的典型JS方法不一致. John Papa在他的控制器和服务中大量使用嵌套的函数声明.这不好吗?

有没有理由支持这个:

var foo = (function() {
    var bar = function() { /* do stuff */ };
    return {
       bar : bar
    };
}());

foo.bar();

对此:

var foo = (function() {
    return {
       bar : bar
    };

    function bar() { /* do stuff */ };
}());

foo.bar();

我主要是一名C#开发人员,仍然习惯于JavaScript的所有细微差别.我更喜欢后一种方法,因为IIFE中的所有功能都是私有的,顶部的揭示模块模式实际上是公共部分.在C#类中,我总是在私有支持函数之前拥有我的公共属性方法.但是,我意识到它在JS世界中可能不那么干脆.

使用后一种方法有哪些隐患(如果有的话)?

解决方法

两种方法之间没有功能差异,只是风格.

JavaScript解释器无形地将函数声明从后一种样式“提升”到嵌套函数的顶部 – 如果没有,则返回块将引用未定义的函数.

猜你在找的JavaScript相关文章