ASP.NET Page和Response 输出js的区别

   前言: 提交成功之后弹出alert对话框,使用Page.ClientScript.RegisterClientScriptBlock和直接   Response.Write("<script type='text/javascript'>" + script + "</script>");

            都能弹出alert内容, 但是,使用Response方法,会对页面的样式发生更改。发生意想不到的页面错乱。原因不明。

    下面是一个JS帮组类

复制代码
  public class JsHelper
    {
        public static HttpResponse Response {
            get { return HttpContext.Current.Response; }
        }
        /// <summary>
        /// 此方法如果页面有服务器文本框控件,将莫名失去样式
        /// </summary>
        /// <param name="script"></param>
        public static void ExecuteScript(string script)
        {
            Response.Write("<script type='text/javascript'>" + script + "</script>");
        }
        /// <summary>
        /// 此方法可以达到预期alert效果,样式不变
        /// </summary>
        /// <param name="script"></param>
        /// <param name="page"></param>
        public static void ExecuteScript(string script,Page page)
        {
            page.ClientScript.RegisterClientScriptBlock(typeof(Page), "msg", "<script type='text/javascript'>" + script + "</script>", false);
        }
        public static void GoToUrl(string url)
        {
            Response.Write("<script type='text/javascript'>top.location.href='" + url + "';</script>");
        }

    }
复制代码

1.使用 public static void ExecuteScript(string script) 方法效果图:

2.使用 public static void ExecuteScript(string script,Page page)方法效果图:

效果图二是正常情况。文本框的样式没有变形。


posted @   正定聚  阅读(846)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示