操作步骤:

给页面隐藏TextBox赋值,然后触发ASP.NET change事件,调用ASP.NET后台方法,调用后执行客户端脚本this.RegisterClientScriptBlock(DateTime.Now.ToString(), script);

执行页面的script;页面的script脚本再次给隐藏TextBox赋值,然后触发ASP.NET change事件;此时没有进入后台的ASP.NET change事件

解决方案:

将this.RegisterClientScriptBlock(DateTime.Now.ToString(), script);更改为Page.RegisterStartupScript(DateTime.Now.ToString(), script);

分析原因:

Response.Write与RegisterStartupScript与RegisterClientScriptBlock之间的区别

方法1,使用Response.Write,这种方法会把JS代码写在页面的最顶部(的前面):
System.Web.HttpContext.Current.Response.Write(" 方法2,使用RegisterStartupScript,这种方法会把JS代码嵌入在页面的底部、表单的最后 (前面),适用于要在页面控件加载完成后运行的JS代码 :
System.Web.UI.Page page = (System.Web.UI.Page)System.Web.HttpContext.Current.Handler;
if (!page.ClientScript.IsStartupScriptRegistered(page.GetType(),"clientScript"))
page.ClientScript.RegisterStartupScript(page.GetType(), "clientScript", " 方法3,使用RegisterClientScriptBlock,这种方法会把JS代码嵌入在页面的顶部、表单的最前 (后面),适用于要在控件加载前执行的JS代码,类似于上面的Response.Write方式 :
System.Web.UI.Page page = (System.Web.UI.Page)System.Web.HttpContext.Current.Handler;
if (!page.ClientScript.IsClientScriptBlockRegistered(page.GetType(),"clientScript"))
page.ClientScript.RegisterClientScriptBlock(page.GetType(), "clientScript", "
那么,方法2和方法3之间有何不同呢?主要区别在于,RegisterStartupScript 方法是将 JavaScript 嵌入到 ASP.NET 页面的底部,恰好位于关闭元素 的前面。 RegisterClientScriptBlock 方法是将 JavaScript 嵌入到页面中开启元素 的紧后面。那么,这有何不同呢?正如我们将要看到的,这有很大的不同。
就此列举一例,以下是在页面加载到浏览器时,将焦点置于该页面上的一个文本框中的方法
- 使用利用了RegisterStartupScript 方法的 Visual Basic: Page.ClientScript.RegisterStartupScript(Me.GetType(), "Testing", _ "document.forms[0]['TextBox1'].focus();", True)
由于在浏览器运行到页面底部并执行此小段 JavaScript 时,就已生成了页面上的文本框,并已将其放到了页面中,因此,此方法运行正常。
但是,如果不按照上述方法,而编写如下代码(使用 RegisterClientScriptBlock 方法): Page.ClientScript.RegisterClientScriptBlock(Me.GetType(), "Testing", _ "document.forms[0]['TextBox1'].focus();", True)
文本框控件将不会获得焦点,且会在页面上生成一个 JavaScript 错误 因为RegisterClientScriptBlock与RegisterStartupScript注册的脚本的位置不同,导致两者使用的场合也有所不同:
1> RegisterClientScriptBlock注册的脚本是在DOM元素未完全加载前执行的,这就导致了,它无法访问页面中几乎所有的html元素;
所以RegisterClientScriptBlock适合写JavaScript函数、警告(在用户点击“确定”之前,页面为空白);
2> RegisterStartupScript注册的脚本也是在DOM元素未完全加载前执行的,可是与RegisterClientScriptBlock不同的是,页面上的大部分DOM元素它都可以访问;
所以RegisterStartupScript不太适合写JavaScript函数,可能调用它写的函数的时候,函数还没加载到页面上呢;
RegisterStartupScript也可以用来写警告,此时,即使用户没有点击“确定”按钮,也可以看到页面的内容;
关于RegisterStartupScript写的警告(alert),如果< / form >后面有JavaScript脚本(直接硬编码在页面上的),且此脚本是控制页面呈现样式的,那么在用户点击警告框中的“确定”按钮前,页面的呈现可能会非预期;
处理表单数据,某个字段不符合要求时,提示:
if (string.IsNullOrEmpty(txtInput.Value.Trim())){ ClientScript.RegisterStartupScript(Page.GetType(), "", "alert('不可以为空!');", true); return;}

最新文章

  1. 订餐系统之Excel批量导入
  2. jffs2文件系统制作
  3. windows在cmd执行svn 命令
  4. 使用HttpWebRequest以及HttpWebResponse读取Http远程文件
  5. Solr与Mysql简单集成
  6. 用eclipse javaEE编程时,不管什么程序都会出现这个错误[SetContextPropertiesRule]{Context} Setting property &#39;source&#39; to &#39;org.eclipse.jst.jee.server:bookstore&#39; did not find
  7. unity3d 制造自己的水体water effect(一)
  8. vbox要手动mount才能挂载windows的共享文件夹(好用,不用安装samba了)
  9. Ichars制作数据统计图
  10. 深入tornado中的http1connection
  11. 强化学习之Q-learning ^_^
  12. JSON Web Token入门教程
  13. 一、学习起步vue——安装
  14. SQLServer之创建显式事务
  15. RSA加解密算法以及密钥格式
  16. java socket编程(一)简介
  17. SpringCloud系列一:SpringCloud的简介和架构
  18. Git的操作方法
  19. JavaScipt 中的事件循环(event loop),以及微任务 和宏任务的概念
  20. iOS开发-UIScrollView图片无限循环

热门文章

  1. Oracle的表锁死以及解锁
  2. 通过transform修改位置 大小 旋转 形变
  3. Java 中文乱码问题总结
  4. python 调用dll中c或c++语言的带指针方法,
  5. [转载]PV操作简单理解
  6. composer 报错:Your requirements could not be resolved to an installable set of packages 解决方法
  7. visual studio 2013 中配置OpenCV2.4.13 姿势
  8. soft-margin SVM
  9. python 使用pymssql连接sql server数据库
  10. foxmail邮箱,签名中如何添加当前日期