UpdatePanel中用后台CS代码调用JS代码,先执行控件事件,后触发JS
2017-06-29 17:21
736 查看
引用地址: http://www.cnblogs.com/silenkee/articles/1609831.html
页面中加入了UpdatePanel后,Response.Write("<script>function dis (){alert('这是调用写在server的JS');}</script>")来调用客户端脚本,无任何提示的无反应。难道没有办法调用客户端脚本了?
方法是有的,那就是采用 ScriptManager.RegisterStartupScript(Control controlId,Type this.GetType(),String key,String script block)方法。ps:有见到过帖子上说controlId必须是UpdatePanel里的,其实不然,page控件就可以。
下面给出一个具体的实例:
protected void Page_Load(object sender, EventArgs e)
{
ScriptManager.RegisterStartupScript(BtnJs, this.GetType(), "alert", "<script>function
dis (){alert('这是调用写在server的JS,如用Response.Write()是不能实现此效果的!!! ');}</script>", false);
}
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" >
</asp:ScriptManager>
<input id="BtnJs" type="button" value="CallServerJs" onclick="dis()" runat="server"/>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional" RenderMode="Block">
<ContentTemplate>
<asp:Button ID="Button1" runat="server" Text="Button" OnClientClick="dis()"/>
</ContentTemplate>
</asp:UpdatePanel>
注意BtnJs是UpdatePanel外的按钮 同时Button1重用了服务端注册的脚本
附带说一下,如果是在普通的aspx中希望在服务器端注册下客户端脚本,可以用
Page.ClientScript.RegisterStartupScript(this.GetType(),
String Key,String Js block ,Bool
AddScriptTag),除了注意粗体字以外,其他操作同上。紫色部分不能包含,如写了的话,浏览时会将脚本部分自动注释掉
页面中加入了UpdatePanel后,Response.Write("<script>function dis (){alert('这是调用写在server的JS');}</script>")来调用客户端脚本,无任何提示的无反应。难道没有办法调用客户端脚本了?
方法是有的,那就是采用 ScriptManager.RegisterStartupScript(Control controlId,Type this.GetType(),String key,String script block)方法。ps:有见到过帖子上说controlId必须是UpdatePanel里的,其实不然,page控件就可以。
下面给出一个具体的实例:
protected void Page_Load(object sender, EventArgs e)
{
ScriptManager.RegisterStartupScript(BtnJs, this.GetType(), "alert", "<script>function
dis (){alert('这是调用写在server的JS,如用Response.Write()是不能实现此效果的!!! ');}</script>", false);
}
<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true" >
</asp:ScriptManager>
<input id="BtnJs" type="button" value="CallServerJs" onclick="dis()" runat="server"/>
<asp:UpdatePanel ID="UpdatePanel1" runat="server" UpdateMode="Conditional" RenderMode="Block">
<ContentTemplate>
<asp:Button ID="Button1" runat="server" Text="Button" OnClientClick="dis()"/>
</ContentTemplate>
</asp:UpdatePanel>
注意BtnJs是UpdatePanel外的按钮 同时Button1重用了服务端注册的脚本
附带说一下,如果是在普通的aspx中希望在服务器端注册下客户端脚本,可以用
Page.ClientScript.RegisterStartupScript(this.GetType(),
String Key,String Js block ,Bool
AddScriptTag),除了注意粗体字以外,其他操作同上。紫色部分不能包含,如写了的话,浏览时会将脚本部分自动注释掉
相关文章推荐
- 让某些服务器控件触发事件时,先调用js函数,在调用后台函数代码
- 引用母版页或在UpdatePanel下JS获取服务器控件的值以及后台JS弹出框
- gridpanel 行双击事件,js带参数调用后台方法
- js调用.net后台事件,和后台调用前台等方法以及js调用服务器控件的方法
- js调用.net后台事件、后台调用前台以及js调用服务器控件
- 不使用ASP.NET服务器端控件(包括form表单不加runat="server")来触发.cs里的事件(方法),(适用于有代码洁癖者)。
- 用代码执行 UpdatePanelControl.Update() 指令来动态决定到底更新哪一个/哪些UpdatePanel区域,并不一定只是更新触发回发的UpdatePanel区域
- ...后台代码中如何调用 javascript 函数的问题! - ASP.NET专题(按钮事件中调用JS文件中函数)
- js代码赋值触发select控件的onchange事件
- 【asp.net 】使用js结合hidden控件实现在后台运行一段程序后提示确认,确认通过后继续执行后台代码~~~
- 如何利用JS实现对后台CS代码的调用
- js如何调用asp.net后台不带参方法?? js如何调用服务端控件事件??
- UpdatePanel 更新后JS调用UpdatePanel外控件
- asp.net后台cs中的JSON格式变量在前台Js中调用方法(前后台示例代码)
- asp.net下利用JS实现对后台CS代码的调用方法
- asp.net 服务器控件LinkButton等在后台代码中设置js事件或添加css样式
- 如何利用JS实现对后台CS代码的调用
- js调用.net后台事件,和后台调用前台等方法以及js调用服务器控件的方法
- 点击button先执行js在执行后台代码客户端判断控件是否为空