将javascript事件挂钩到页面加载

问题描述 投票:22回答:5

我有一个aspx,在正文的onload事件期间运行以下javascript函数。

<body onload="startClock();">

但是,我将aspx设置为使用母版页,因此aspx中不存在body标签。如何在页面被命中时注册startClock函数并仍然使用主页?

javascript master-pages asp.net onload-event
5个回答
36
投票

如果您不想显式分配window.onload或使用框架,请考虑:

<script type="text/javascript">
function startClock(){
    //do onload work
}
if(window.addEventListener) {
    window.addEventListener('load',startClock,false); //W3C
} else {
    window.attachEvent('onload',startClock); //IE
}
</script>

http://www.quirksmode.org/js/events_advanced.html


2
投票

将其插入页面正文的任何​​位置:

<script type="text/javascript">
window.onload = function(){
    //do something here
}
</script>

1
投票

最干净的方法是使用像jQuery这样的javascript框架。在jQuery中,您可以通过以下方式定义on-load函数:

$(function() {
    // ...
});

或者,如果你不喜欢短的$();风格:

$(document).ready(function() {
    // ...
});

0
投票
Page.ClientScriptManager.RegisterStartupScrip(this.GetType(), "startup", "startClock();", true);

或使用原型

document.observe("dom:loaded", function() {
  // code here
});

0
投票
window.addEventListener("load", function() {
    startClock();
}

这将在页面加载时调用startClock函数。

© www.soinside.com 2019 - 2024. All rights reserved.