zoukankan      html  css  js  c++  java
  • ASP.NET 给作为隐藏域的TextBox赋值之后提交表单,无响应?

    操作步骤:

    给页面隐藏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;}
  • 相关阅读:
    Java实现 蓝桥杯 算法训练 Number Challenge(暴力)
    Java实现 蓝桥杯 算法训练 Number Challenge(暴力)
    Java实现 蓝桥杯 算法训练 Number Challenge(暴力)
    Java实现 蓝桥杯 算法训练 Rotatable Number(暴力)
    Java实现 蓝桥杯 算法训练 Rotatable Number(暴力)
    Java实现 蓝桥杯 算法训练 Rotatable Number(暴力)
    Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)
    Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)
    Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)
    Python位运算符
  • 原文地址:https://www.cnblogs.com/licin/p/5880646.html
Copyright © 2011-2022 走看看