ASP.NET 给作为隐藏域的TextBox赋值之后提交表…
2018-06-22 07:36:03来源:未知 阅读 ()
操作步骤:
给页面隐藏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;}
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- asp.net源程序编译为dll文件并调用的实现过程 2020-03-29
- Asp.net MVC SignalR来做实时Web聊天实例代码 2020-03-29
- ASP.NET MVC中jQuery与angularjs混合应用传参并绑定数据 2020-03-29
- Asp.Net中WebForm的生命周期 2020-03-29
- ASP.NET使用Ajax返回Json对象的方法 2020-03-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash