Wywołanie zwrotne ładowania asynchronicznego skryptu
http://jsfiddle.net/JamesKyle/HQDu6/
Stworzyłem krótką funkcję opartą naMathias Bynens Optymalizacja asynchronicznego skryptu Google Analytics to wygląda następująco:
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);
}
To działa świetnie i już zacząłem używać go do kilku różnych skryptów
// 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');
Problem pojawia się, gdy napotykam skrypt, który należy wywołać po załadowaniu:
// Snap Engage
async('snapabug.appspot.com/snapabug.js');
SnapABug.init('XXXXX-XXXXX-XXXXX-XXXXX-XXXXX');
Pomyślałem, że zmienię to w funkcję wywołania zwrotnego, która będzie używana w następujący sposób:
async('snapabug.appspot.com/snapabug.js', function() {
SnapABug.init('XXXXX-XXXXX-XXXXX-XXXXX-XXXXX');
});
Nie spodziewałem się, że to będzie dla mnie trudne, ale okazało się, że tak jest.
Moje pytanie brzmi: co jest najbardziej skutecznym sposobem dodania wywołania zwrotnego bez nadmiernego komplikowania kodu.Zobacz jsfiddle:http://jsfiddle.net/JamesKyle/HQDu6/