我正在加载一个异步创建的脚本,以帮助防止网站变慢。我无法调用 Class.track({"some_param":"some_data"}) 类,因为它还不可用。如何实现异步加载并具有调用类的能力?
在 js 中加载的代码如下,它发生在结束 body 标记之前,并且 Class.track 在它下面被调用。
<script type="text/javascript">
(function() {
function async_load(){
var api_id = "XXXXXXXXX";
var s = document.createElement('script');
s.type = 'text/javascript';
s.async = true;
s.src = 'https://site.com/script.js?id=' + api_id;
var x = document.getElementsByTagName('script')[0];
x.parentNode.insertBefore(s, x);
}
if (window.attachEvent)
window.attachEvent('onload', async_load);
else
window.addEventListener('load', async_load, false);
})();
Class.track("page_view", {"page":"plans"});
</script>
编辑
听取了 Dan 的评论和 TJ 的回答并决定对其进行修改,以下是我的想法,希望这对其他人有所帮助。
<script type="text/javascript">
var _Class = new function(){
var items = [];
this.track = function(type, params){
params = params || {};
items.push({"type":type, "params":params});
}
this.get = function(){
return items;
}
};
var Class = _Class;
(function() {
function async_load(){
var api_id = "XXXXXXXXX";
var s = document.createElement('script');
s.type = 'text/javascript';
s.async = true;
s.src = 'https://site.com/script.js?id=' + api_id;
s.onload = function(){
var items = _Class.get();
Class.trackBatch(items);
};
var x = document.getElementsByTagName('script')[0];
x.parentNode.insertBefore(s, x);
}
if (window.attachEvent)
window.attachEvent('onload', async_load);
else
window.addEventListener('load', async_load, false);
})();
Class.track("page_view", {"page":"plans"});
</script>