javascript - 函数覆盖、onload 优先

标签 javascript

我正在开发一些库并创建了这个有缺陷的代码:

//-------------------
Gmaps = {};
Gmaps.map = new Gmaps4RailsGoogle(); //there exists a default callback function in the created object
function load_map() {
  Gmaps.map.callback();
};
window.onload = load_map();
//--------------------
Gmaps.map.callback = function(){ alert('ok'); }

我想,因为整个页面已加载,回调会被更改并显示警报消息。

但事实并非如此,我在 firebug 中没有任何错误消息。

如果我然后在控制台中执行Gmaps.map.callback(),它就可以正常工作。

有什么原因导致回调未被覆盖吗?

出于上下文考虑,--------- 之间的代码是由库创建的,但开发人员可以覆盖其 html 中的某些函数。

最佳答案

您没有执行 load_map onload。您将在此处立即执行它:

window.onload = load_map();

并将其返回值存储在window.onload中,因此加载时不会发生任何事情。只需将该行更改为:

window.onload = load_map;

关于javascript - 函数覆盖、onload 优先,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7216459/

相关文章:

javascript - NGRX Effect withLatestFrom Typescript 错误 ts2345 故障排除

javascript - Laravel 在 JavaScript 中的链接

javascript - 如何在 DOM 中的克隆/插入元素上触发事件?

javascript - 如何包含一个将许多 javascript 加载到 HTML 文件的 header 中的通用文件

javascript - 如何清理最不常用的 Node 包?

javascript - 仅首页的 PDF 页脚

javascript - 计算字符串中的大小写字符

javascript - 注销 Windows 身份验证 IIS 8 : using php and javascript

javascript - 如何为 float div 的重新洗牌设置动画?

javascript - 在 javascript 中将参数传递给 ajax 调用