上一章写了asp.net中registerstartupscript方法的使用,在.net framework中与此相似的还有方法:registerclientscriptblock. 这两个方法的作用都是从前台向后台写脚本, 这两个方法唯一的不同之处在于从“何处”发送脚本块。registerclientscriptblock() 在 web 窗体的开始处(紧接着 <form runat="server"> 标识之后)发送脚本块,而 registerstartupscript() 在 web 窗体的结尾处(在 </form> 标识之前)发送脚本块。
registerstartupscript() 用于添加要在加载页面后运行的脚本块,通过这种方法添加的脚本块位于 web 窗体的结尾处,因为必须在脚本运行前定义脚本要修改的 html 元素。也就是说,如果您要使用客户端脚本将焦点设置到文本框,必须确保文本框的 html 标记位于设置该文本框的焦点的脚本之前。
registerclientscriptblock() 方法用于为响应客户端事件而执行的脚本代码。通过此方法发送的脚本块位于 web 页面的开始处,因为这种方法不要求将脚本块置于所有 html 元素之后,即它一般不使用文档内自定义的控件。
如果你仅仅是注册一些函数,这两者的效果是一样的。但如果你要注册一些全局的脚本,如定义一些全局变量并赋值,那么它在html中的先后位置可能就比较重要,此时就应该用registerstartupscript保证脚本能在前面被执行。
以下是该方法的一个使用实例(见msdn):
<html>
<head>
<script language="vb" runat="server">
sub page_load( sender as object,e as eventargs)
'form the script that is to be registered at client side.
dim scriptstring as string = "<script language=javascript> function doclick() {"
scriptstring += "myform.show.value='welcome to microsoft .net'}<"
scriptstring += "/"
scriptstring += "script>"
if(not isclientscriptblockregistered("clientscript"))
registerclientscriptblock("clientscript", scriptstring)
end if
end sub
</script>
</head>
<body topmargin="20" leftmargin="10">
<form id="myform" runat="server">
<input type="text" id="show" >
<input type="button" value="clickme" >
</form>
</body>
</html>
新闻热点
疑难解答
图片精选