我创建了一个基于Google Analytics 异步脚本的 Mathias Bynens 优化的简短函数,如下所示:
function async(src) {
var d = document, t = 'script',
o = d.createElement(t),
s = d.getElementsByTagName(t)[0];
o.src = '//' + src;
s.parentNode.insertBefore(o, s);
}
这很好用,我已经开始将它用于几个不同的脚本
// Crazy Egg
async('dnn506yrbagrg.cloudfront.net/pages/scripts/XXXXX/XXXXX.js?' + Math.floor(new Date().getTime() / 3600000));
// User Voice
var uvOptions = {};
async('widget.uservoice.com/XXXXX.js');
// Google Analytics
var _gaq = [['_setAccount', 'UA-XXXXX-XX'], ['_setDomainName', 'coachup.com'], ['_trackPageview']];
async('google-analytics.com/ga.js');
// Stripe
async('js.stripe.com/v1');
当我遇到加载后需要调用的脚本时,问题就来了:
// Snap Engage
async('snapabug.appspot.com/snapabug.js');
SnapABug.init('XXXXX-XXXXX-XXXXX-XXXXX-XXXXX');
所以我想我会把它变成一个回调函数,这样可以使用:
async('snapabug.appspot.com/snapabug.js', function() {
SnapABug.init('XXXXX-XXXXX-XXXXX-XXXXX-XXXXX');
});
我没想到这对我来说很难,但事实证明是这样的。
我的问题是在不使代码过于复杂的情况下添加回调的最有效方法是什么。
请参阅 jsfiddle:http: //jsfiddle.net/JamesKyle/HQDu6/