jsfiddle
https://jsfiddle.net/ee7oe5pb/2/
Javascript
var events = (function () {
var fn = {};
fn.refresh = function(message) {
alert(message);
}
return fn;
})();
var menu = (function () {
var fn = {};
fn.init = function(message) {
events.refresh('Work from the function root'); // Work
document.addEventListener("DOMContentLoaded", function() {
events.refresh('Work from the domcontentloaded'); // Don't work
});
}
return fn;
})();
menu.init();
问题
运行menu.init时它会启动菜单初始化功能。它触发events.refresh功能并通过消息发出警报。那部分工作得很好。
在范围内events.refresh也调用了DOMContentLoaded。当页面完全加载时触发。现在events.refresh是undefined function。为什么?我怎样才能绕过它?