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

方法1,使用Response.Write,这种方法会把JS代码写在页面的最顶部(<html>的前面):
System.Web.HttpContext.Current.Response.Write("<script language=javascript>alert(JS代码);</script>");

方法2,使用RegisterStartupScript,这种方法会把JS代码嵌入在页面的底部、表单的最后 (</form>前面),适用于要在页面控件加载完成后运行的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", "<script
language=javascript>alert(JS代码);</script>");

方法3,使用RegisterClientScriptBlock,这种方法会把JS代码嵌入在页面的顶部、表单的最前 (<form>后面),适用于要在控件加载前执行的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", "<script
language=javascript>alert(JS代码);</script>");

  那么,方
法2和方法3之间有何不同呢?主要区别在于,RegisterStartupScript 方法是将 JavaScript 嵌入到 ASP.NET
页面的底部,恰好位于关闭元素 </form> 的前面。RegisterClientScriptBlock 方法是将
JavaScript 嵌入到页面中开启元素 <form> 的紧后面。那么,这有何不同呢?正如我们将要看到的,这有很大的不同。

就此列举一例,以下是在页面加载到浏览器时,将焦点置于该页面上的一个文本框中的方法 - 使用利用了 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 错误。

Page

大家都知道向客户端输出内容的方式很多,而打多少初学者会使用Respone.Write(string)。比如:

Respone.Write(“hello word!”);

或输出JS

Respone.Write("<script type='text/javascript'>alert('hello word!');</script>");

但是,当你查看客户端源码时,你会发现,输出的内容呈现在源码的最前端,显然它破坏了HTML的格式,在某些情况下这是会影响到页面布局等效果的。

正确的输出方式应该是:this.ClientScript.RegisterStartupScript或this.ClientScript.RegisterClientScriptBlock.

this.ClientScript.RegisterStartupScript 是在Form开始的第一行注册脚本,后者则是在Form结尾处注册脚本。这样就不回破坏HTML得格式了,如:

this.ClientScript.RegisterStartupScript(this.GetType(), "scriptKey", "<script type='text/javascript'>alert('hello word!');</script>")

this.ClientScript.RegisterStartupScript(this.GetType(), "scriptKey", "alert('hello word!');",True)

this.ClientScript.RegisterClientScriptBlock也类似。

UpdatePanel

当你想在UpdatePanel内输出一段JS时,运用以上方法就会得不到预期的效果。那么请看一下示例。

有一个UpdatePanel的ID是upPn

System.Web.UI.ScriptManager.RegisterClientScriptBlock(upPn,this.GetType(), "scriptKey", "alert('hello word!');",True)

System.Web.UI.ScriptManager.RegisterStartupScript(upPn,this.GetType(), "scriptKey", "alert('hello word!');",True)

这样的话,当UpdatePanel内容加载到客户端后,就会弹出“hello word!”对话框。

这样的话,从后台输出JS就更加方便了。

报错错误例:

消息: Sys.WebForms.PageRequestManagerParserErrorException: 未能分析从服务器收到的消息。

首先不能与这类AJAX控件共存
<RadAjax:RadAjaxManager ID="RadAjaxManager1" runat="server">
<AjaxSettings>
<RadAjax:AjaxSetting AjaxControlID="Button1">
<UpdatedControls>
<RadAjax:AjaxUpdatedControl ControlID="rcaldate" />
<RadAjax:AjaxUpdatedControl ControlID="rcbsex" />
<RadAjax:AjaxUpdatedControl ControlID="rtxtmemberid" />
<RadAjax:AjaxUpdatedControl ControlID="rcbxiaoshouyuan" />
<RadAjax:AjaxUpdatedControl ControlID="rtxtlastjifen" />
<RadAjax:AjaxUpdatedControl ControlID="rtxtlastjfmoney" />
<RadAjax:AjaxUpdatedControl ControlID="rcbprice" />
<RadAjax:AjaxUpdatedControl ControlID="rcbvip" />
<RadAjax:AjaxUpdatedControl ControlID="rtxtfangjia" />
</UpdatedControls>
</RadAjax:AjaxSetting>
</AjaxSettings>
</RadAjax:RadAjaxManager> 在用Response.Redirect()或Response.Write()进行URL带参数的页面重定向时出现如题所示的错误。
1:Ajax是无刷新的,而使用Response进行带参重定向时需要刷新页面。所以只须在UpdatePanel下设置“asp:PostBackTrigger”的“ControlID”为指定的控件名称即可,如:
<Triggers>
<asp:PostBackTrigger ControlID="btnSave" />
</Triggers> 2:如果你用的是微软的ajax框架,弹出提示框应该用:
ScriptManager.RegisterStartupScript(this.UpdatePanel1, this.GetType(), "updateScript", "alert('对不起,账号和密码错误');", true); 3:EnableEventValidation="false"

System.Web.UI.ScriptManager.RegisterClientScriptInclude 后台加载JS文件

  string _RootPath = HttpContext.Current.Request.ApplicationPath;
// Define the name, type and url of the client script on the page.
String csname = "ButtonClickScript";
String csurl = _RootPath + "script_include.js";
Type cstype = this.GetType(); // Get a ClientScriptManager reference from the Page class.
ClientScriptManager cs = Page.ClientScript; // Check to see if the include script exists already.
if (!cs.IsClientScriptIncludeRegistered(cstype, csname))
{
cs.RegisterClientScriptInclude(cstype, csname, csurl);
}

asp.net中使用updatepanel 来实现异步导致js无效

asp.net做网站,为了简单,ajax直接使用了updatepanel来处理,结果updatepanel中的js效果,第一次加载是有效的,一旦updatepanel中使用了异步事件,js就无效了。网上找了一些答案,还是有效的。分享一下。

因为Updatapanel没有postback,你的js不会重新加载。所以失效。你在你的页面加一段这样的代码就可以了: <script type="text/javascript" language="javascript">

var prm = Sys.WebForms.PageRequestManager.getInstance();

prm.add_endRequest(function () {

// re-bind your jquery events here

$(document).ready(function(){

//页面中需要处理的js代码

});

});

</script>

上面这个问题,能解决自己编写的js(类似函数调用),但有些效果是直接通过引用外站提供的js代码,并没有任何调用(应该在引入的js脚本中实现了调用),上面的就没法处理了。

没有办法的办法,就是页面多写几个updatepanel,把有js的部分跳过。

其它方法:

/*方法一、*/
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<input src="../../../images/ico/ico_delete.gif" onload="reBindDatepicker()" style="display: none" id="Image1" type="image" />
</ContentTemplate>
</asp:UpdatePanel> <script type="text/javascript">
function reBindDatepicker() {
$(document).ready(function() {
//...
});
}
</script> /*方法二、*/
$(document).ready(function() {
// bind your jQuery events here initially
}); var prm = Sys.WebForms.PageRequestManager.getInstance(); prm.add_endRequest(function() {
// re-bind your jQuery events here
});

the solution is from :
http://elves.cnblogs.com/

消息: Sys.WebForms.PageRequestManagerParserErrorException: 未能分析从服务器收到的消息。

ASP.NET后台输出js大全,页面顶部、form表单中前面与后面、和UpdatePanel(ScriptManager、AJAX)输出JS的更多相关文章

  1. asp.net使用post方式action到另一个页面,在另一个页面接受form表单的值!(报错,已解决!)

    原文:asp.net使用post方式action到另一个页面,在另一个页面接受form表单的值!(报错,已解决!) 我想用post的方式把一个页面表单的值,传到另一个页面.当我点击Default.as ...

  2. 当一个页面中有多个form表单并且有重名的元素时,js获取指定form表单中的指定元素

    有时候我们会在一个页面中写了多个form表单,碰巧多个form表单中又有相同名称的元素,而我们又不想改名字,这个时候就能用到 $("#form1 #div1").val() 好玩吧 ...

  3. jQuery中设置form表单中action值与js有什么不同。。。。

    jQuery中设置form表单中action值与js有什么不同.... HTML代码如下: <form action="" method="post" i ...

  4. MSCRM4.0如何使js事件在批量编辑表单中触发

    MSCRM4.0如何使js事件在批量编辑表单中触发 MSCRM4.0如何使js事件在批量编辑表单中触发 MSCRM3.0我们可以通过在onload事件加入以下代码来控制某个属性为只读.crmForm. ...

  5. form表单中的button自动刷新页面问题

    form表单中如果存在button的话,有可能会出现一个问题:点击button,触发了页面的自动刷新事件. 原因是因为<button>标签默认的类型是submit,即默认的button点击 ...

  6. js控制页面显示和表单提交

    早期的web页面在显示方面一般在后台进行控制,虽然对后台开发来讲是比较容易做到的,但是涉及到一个问题,那就是数据库压力. 因为要控制显示,所以会比较频繁的从数据库中来回调用. 现在的js功能越来越强, ...

  7. 纯js将form表单的数据封装成json 以便于ajax发送

    使用方式: var json = form2Json("formId");//这里的参数是form表单的id值 form2json.js function form2Json(fo ...

  8. js 取值&赋值-form表单

      form表单元素介绍 CreateTime--2016年9月22日10:25:54 Author:Marydon <form> 表单元素. 表单中的元素: <input>表 ...

  9. 防止表单提交时刷新页面-阻止form表单的默认提交行为

    最近在写 ajax 提交的时候遇到一个问题,在执行 ajax 提交之后,浏览器页面自动刷新了,主要是没有 由于form 表单的默认提交行为.一下是几种阻止 form 表单默认提交行为的方式. 1.使用 ...

随机推荐

  1. 第三次个人作业——关于K米(Andorid)的案例分析

    第三次个人作业--关于K米(Andorid)的案例分析 1.K米简介 官方网址:http://www.ktvme.com/ 2.评测 2.1.上手体验 带着找bug的心态,兴致勃勃地开始体验 K米.打 ...

  2. 全栈必备 Linux 基础

    Linux 几乎无处不在,不论是服务器构建,还是客户端开发,操作系统的基础技能对全栈来说都是必备的.系统的选择Linux发行版本可以大体分为两类,一类是商业公司维护的发行版本,一类是社区组织维护的发行 ...

  3. jQuery知识点总结(第一天)

    整理笔记前的题外话: 我认为互联网的高速发展其中最为主要的一点就是——开源. 开源精神,使得无数的IT爱好者贡献所学,将自己的智慧结晶无偿奉献给大家.后辈的学习者在混沌的互联网世界里,追寻着前辈们留下 ...

  4. spring+hibernate ---laobai

    biz包: package com.etc.biz; import java.util.List; import org.springframework.orm.hibernate3.support. ...

  5. zabbix监控模式、分布式、自动化

    适用场景: 1.监控主机多,性能瓶颈 2.多机房,防火墙 zabbix监控模式 针对agent来说 - 被动模式 - 主动模式(主动汇报服务端) 1)当监控主机超过300台,建议使用主动模式 2)当队 ...

  6. 为什么springMVC和Mybatis逐渐流行起来了?

    http://www.zhihu.com/question/36032573 https://github.com/bingoohuang/eql

  7. 【原】redux学习笔记

    上周学习了flux,这周研究了一下redux,其实很早之前都已经在研究他们了,只是之前一直没搞懂,最近这两周可能打通了任督二脉,都算入门了. 写博客的目的主要是做一下笔记,总结一下思路,以及和大家交流 ...

  8. Bois设置教程

    BIOS设置图解教程之Award篇 (目前主板上常见的BIOS主要为AMI与AWARD两个系列,如何辨别BIOS品牌系列请移步,本文详细讲解Award系列的BIOS设置图解教程,如果你的BIOS为AM ...

  9. Java——表格

    import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import javax.swing.JFrame; i ...

  10. 初识Python类

    吐槽:学习面向对象就像你追一个女神一样,刚刚有点感觉了,过几天又陷入绝望的感觉,很蛋疼. 类的语法 class Person(object): print("learning class&q ...