现在的位置: 首页 > 综合 > 正文

asp.net中使用对话框提交时页面出现白屏

2013年10月17日 ⁄ 综合 ⁄ 共 1849字 ⁄ 字号 评论关闭

 如果使用弹出对话框的代码如下,则经常会在使用对话框提交时页面出现背景白屏的现象

    Protected Sub Msg(ByVal strMsg As String)
        Response.Write("<Script language='JavaScript'>alert('" & strMsg & "')</Script>")
    End Sub

解决的办法,更改这段代码为:

    Protected Sub Msg1(ByVal strMsg As String)
        Page.RegisterStartupScript("check", "<Script language='JavaScript'>alert('" & strMsg & "')</Script>")
    End Sub

 

 

以下内容转:RegisterStartupScript和RegisterClientScriptBlock输出位置的区别

Page.Response.Write("<script>var response;</script>");    

Page.RegisterStartupScript("RegisterStartupScript","<script>var RegisterStartupScript;</script>");    

Page.RegisterClientScriptBlock("RegisterClientScriptBlock","<script>var RegisterClientScriptBlock;</script>");   

Response.Write输出后的位置在源文件的第一行.

RegisterClientScriptBlock输出后的位置会在<form>的下一行.(在asp.net自带的脚本和一些隐藏域之下).

RegisterStartupScript输出后的位置会在</form>的上一行.

RegisterClientScriptBlock的原型与RegisterStartupScript相同,两个函数不同在于将其包含的脚本代码写入到HTML文件的不同位置.RegisterClientScriptBlock在 Page 对象的 元素的开始标记后立即发出客户端脚本,RegisterStartupScript则是在Page 对象的 元素的结束标记之前发出该脚本。如果你的脚本有与页面对象(doucument对象)进行交互的语句,则推荐使用RegisterStartupScript,反之如果要想客户端脚本尽可能早的执行,则可以使用RegisterClientScriptBlock或Response.Write。

RegisterClientScriptBlock一般返回的是客户端函数的包装,而RegisterStartupScript返回得函数在document装载完成后会执行,类似于我们平时所说的body onload="f()"里面的函数;这两个方法在客户端呈现的代码位置不同,RegisterClientScriptBlock在<form runat=server>之后,而RegisterStartupScript在</form>之前。

补充例子:
....
</HEAD>
<body MS_POSITIONING="GridLayout">
<form name="Form1" method="post" action="WebForm6.aspx" id="Form1">
           <input type="hidden" name="__VIEWSTATE" value="dDw3MzU1MTQ5MzY7Oz6nugrEg+5T6RC7MTIuLoIrMLQLPw==" />
<script>function block(){}</script>    ------------>RegisterClientScriptBlock()方法输出的在这里

<input name="TextBox1" type="text" id="TextBox1" style="Z-INDEX: 101; LEFT: 296px; POSITION: absolute; TOP: 120px" />

            <script>function startup(){}</script> ------------>RegisterStartupScript()方法输出的在这里

</form>
</body>
</HTML>

 

抱歉!评论已关闭.