我是靠谱客的博主 聪明豌豆,最近开发中收集的这篇文章主要介绍 page.registerstartupscript ,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

msdn如下说

   允许 asp.net 服务器控件在 page 中发出客户端脚本块。
    [C#]
    public virtual void RegisterStartupScript(
       string key,
       string script
    );
参数
    key
        标识脚本块的唯一键。
    script
        要发送到客户端的脚本的内容。
 
以下是一些应用实例:

打开一个新窗口:
    page.registerstartupscript("starup", "<script language= 'javascript'>window.open('" + url + "','','toolbar=no,resizable=yes,scrollbars=yes')</script>")
警告窗口
// <summary>
// 服务器端弹出alert对话框
// </summary>
// <param name="str_message">提示信息,例子:"不能为空!"</param>
// <param name="page">page类</param>
public void alert(string str_message,page page)
{
page.registerstartupscript("","<script>alert('"+str_message+"');</script>");
}
重载此警告窗口,使某控件获得焦点
// <summary>
// 服务器端弹出alert对话框,并使控件获得焦点
// </summary>
// <param name="str_ctl_name">获得焦点控件id值,比如:txt_name</param>
// <param name="str_message">提示信息,例子:"请输入您姓名!"</param>
// <param name="page">page类</param>
public void alert(string str_ctl_name,string str_message,page page)
{
page.registerstartupscript("","<script>alert('"+str_message+"');document.forms(0)."+str_ctl_name+".focus(); document.forms(0)."+str_ctl_name+".select();</script>");
}
确认对话框
// <summary>
// 服务器端弹出confirm对话框
// </summary>
// <param name="str_message">提示信息,例子:"您是否确认删除!"</param>
// <param name="btn">隐藏botton按钮id值,比如:btn_flow</param>
// <param name="page">page类</param>
public void confirm(string str_message,string btn,page page)
{
page.registerstartupscript("","<script> if (confirm('"+str_message+"')==true){document.forms(0)."+btn+".click();}</script>");
}
重载确认对话框,点击确定触发一个隐藏按钮事件,点击取消触发一个隐藏按钮事件
// <summary>
// 服务器端弹出confirm对话框,询问用户准备转向那些操作,包括“确定”和“取消”时的操作
// </summary>
// <param name="str_message">提示信息,比如:"成功增加数据,单击/"确定/"按钮填写流程,单击/"取消/"修改数据"</param>
// <param name="btn_redirect_flow">"确定"按钮id值</param>
// <param name="btn_redirect_self">"取消"按钮id值</param>
// <param name="page">page类</param>
public void confirm(string str_message,string btn_redirect_flow,string btn_redirect_self,page page)
{
page.registerstartupscript("","<script> if (confirm('"+str_message+"')==true){document.forms(0)."+btn_redirect_flow+".click();}else{document.forms(0)."+btn_redirect_self+".click();}</script>");
}

获得焦点
// <summary>
// 使控件获得焦点
// </summary>
// <param name="str_ctl_name">获得焦点控件id值,比如:txt_name</param>
// <param name="page">page类</param>
public void getfocus(string str_ctl_name,page page)
{
page.registerstartupscript("","<script>document.forms(0)."+str_ctl_name+".focus(); document.forms(0)."+str_ctl_name+".select();</script>");
}
子窗体返回主窗体
//<summary>
//名称:redirect
//功能:子窗体返回主窗体
//参数:url
//返回值:空
//</summary>
public void redirect(string url,page page)
{
if ( session["ifdefault"]!=(object)"default")
{
page.registerstartupscript("","<script>window.top.document.location.href='/webjx/"+url+"';</script>");
}

 

Page.RegisterStartupScript与Response.Write的区别

 

一般来说有三种情况    
  (1)在前台放置<asp:Literal   Runat="server"></asp:Literal>指定位置输出    
  (2)后台通过RegisterStartupScript和RegisterClientScriptBlock输出    
  (3)Response.Write输出    
  举例如下    
  (1)    
  前台    
  <asp:Literal   ID="myLiteral"   Runat="server"></asp:Literal>    
  后台    
  this.myLiteral.Text+="<script>alert('test');</script>";    
  查看源代码可以看到原来的    
  <asp:Literal   ID="myLiteral"   Runat="server"></asp:Literal>    
  位置变成了    
  <script>alert('test');</script>    
  (2)    
  为了更加清楚看到两个的区别,前台如下    
  <form   id="Form1"   method="post"   runat="server">    
  <input   type="hidden"   value="test"   id="myhiden">    
  </form>    
  后台如下    
  Page.RegisterStartupScript("","<script>alert('RegisterStartupScript:'+document.all.myhiden.value)</script>");    
  Page.RegisterClientScriptBlock("","<script>alert('RegisterClientScriptBlock:'+document.all.myhiden.value)</script>");    
  结果如下:只出现对话框显示RegisterStartupScript:test    
  查看源代码如下:    
  <form   name="Form1"   method="post"   action="WebForm4.aspx"   id="Form1">    
  <input   type="hidden"   name="__VIEWSTATE"   value="dDwtNjU0MzcyMTk1Ozs+NmbLf6dWkF/Q/FLKKsdPPfhFXr0="   />    
  <script>alert('RegisterClientScriptBlock:'+document.all.myhiden.value)</script>    
  <input   type="hidden"   value="test"   id="myhiden">    
  <script>alert('RegisterStartupScript:'+document.all.myhiden.value)</script>    
  </form>    
  两者区别不用多说了吧    
  (3)    
  我们再加一句Response.Write("test")    
  查看源代码发现test字样出现在最前面    
  test    
  <!DOCTYPE   HTML   PUBLIC   "-//W3C//DTD   HTML   4.0   Transitional//EN"   >    
  用它来输出转向代码比较合适    
  <script>location.href='page.aspx'</script>    
   
  最后在提醒一下大家,有很多人在给一个控件加js代码的时候会这么写:    
  this.mybody.Attributes["onclick"]="<script>alert('test');</script>";    
  这么写是不对的    
  应该是    
  this.mybody.Attributes["onclick"]="alert('test');";    
  比如你在前台书写<a   οnclick=>的时候你会写<a   οnclick='<script>alert('test')<script>'>吗?    
  道理是一样的!    
  但是相反,有的人在    
  Page.RegisterStartupScript("","<script>alert('test');</script>");的时候不写里面的<script>也是不行的    
  (虽然名字叫Register...Script)    

Response.Write(" <script>");输出在文件头部,一打开就执行。 
而RegisterStartupScript返回得函数在document装载完成后会执行,类似于我们平时所说的body οnlοad="f()"里面的函数;
====
还有就是这两个都无所谓发回到服务器不发回到服务器之说,他们都是从服务器返回的对客户端的请求,只不过 Response.Write是放到最开头,也就是页面的 <html>标签,而js是解释性的语言, <html>之前的js语句会被解释,所以说,用Response.Write的效果如下:
<script>alert('弹出对话框') </script>//遇到这句之后,就会弹出对话框。
<html>
....
而弹出对话框未点确定之前,页面什么东西都没有,点了确定之后继续解释其他的语句,所以就像回发到服务器一样,其实不是回发到了服务器。
而RegisterStartupScript就是在页面加载完之后的事情了,此时,页面已经完全呈现出来了,所以不会在刷新...

 

最后

以上就是聪明豌豆为你收集整理的 page.registerstartupscript 的全部内容,希望文章能够帮你解决 page.registerstartupscript 所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(51)

评论列表共有 0 条评论

立即
投稿
返回
顶部