angularJS自执行函数的妙用

本文介绍如何通过立即执行函数表达式(IIFE)来为每个JavaScript文件创建独立的作用域,以此避免在Angular应用中引入全局变量污染的问题。推荐的方法能够确保模块间的隔离性,提高代码的可维护性和质量。
自执行函数(IIFE),给每个文件提供一个独立的作用域 

/* avoid */
// logger.js
angular
    .module('app')
    .factory('logger', logger);

// logger function会被当作一个全局变量
function logger() { }

// storage.js
angular
    .module('app')
    .factory('storage', storage);

// storage function会被当作一个全局变量
function storage() { }
/**
* recommended
*
* 再也不存在全局变量了
*/

// logger.js
(function() {
    'use strict';

    angular
        .module('app')
        .factory('logger', logger);

    function logger() { }
})();

// storage.js
(function() {
    'use strict';

    angular
        .module('app')
        .factory('storage', storage);

    function storage() { }
})();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值