欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

RegisterStartupScript(key, script) 等价于body.onload=f(){}里的内容?!

程序员文章站 2022-06-11 09:29:22
...

关于RegisterClientScriptBlock和RegisterStartupScript的区别,网上很多贴子是这么解释的:

这两个方法唯一的不同之处在于向“何处”注册脚本块。
         RegisterClientScriptBlock(key, script) 在 form开始处(紧接 <form runat="server"> 标识之后)发送脚本块      
         使用场景:               一般不使用DOM元素
         RegisterStartupScript(key, script) 在 form结尾处(在 </form> 标识之前)发送脚本块,在document装载完成后会执行,等价于body.onload=f(){}里的内容
         使用场景:               一般要使用DOM元素,比如:修改dom元素的值等
实验一下,我们发现:
RegisterClientScriptBlock(key, script) 在 form开始处(紧接 <form runat="server"> 标识之后)发送脚本块 
RegisterStartupScript(key, script) 在 form结尾处(在 </form> 标识之前)发送脚本块
这是这两个方法的区别。但问题是:
在 form结尾处(在 </form> 标识之前)发送脚本块,等价于body.onload=f(){}里的内容吗?显然不是啊!
比如,
如果我们的DOM对象放在<form></form>之后,在body.onload中的JS函数,仍然是可以访问的,但放在
RegisterStartupScript(key, script) 仍然无法访问!
 
 
 
比如下面的页面结构:
 
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="1.aspx.cs" Inherits="rent._1" %>
 
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 <html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
    <script type="text/javascript">
        function f() {
            alert(document.getElementById("spn1").innerText);
        }
    </script>
</head>
<body>
    <form id="form1" runat="server">
    <div>
    
    </div>
    </form>
    <spn id="spn1">Span Text</spn>
</body>
</html>

用下面的方法扫行f(),JS是无法取得DOM对象spn1的:

protected void Page_Load(object sender, EventArgs e)

        {

            RegisterStartupScript("scr_login", "<script type=\"text/javascript\">f();</script>");

        }

    }

 

 

所以,结论是:

RegisterStartupScript(key, script) 并不等价于body.onload=f(){}
 
 
关于RegisterClientScriptBlock和RegisterStartupScript的区别,只是前者被放在了<form>之后,
 
而后者放了在了</form>之前(能够访问form之前和form之中,但不能访问form之后的DOM对象),仅此而已!
 
 
最后,再讨论一个问题:脚本放在<body onload="f1();">,和放在HTML文档最后面有区别吗?
 
放在<body onload="f1();">中,要等到整个页面所有元素(包括所有图片)都加载完成之后才能执行,这时可以获取到页面上图片的尺寸。
放在HTML最后面,只要html文件加载并解析到最后就能执行,这时可以获取到页面上的元素,却不能获取到页面上图片的尺寸。