• 【原创】Discuz!NT中返回的实现方式


      转载请注明文章来源:http://www.cnblogs.com/Excellent/

      在博客园混迹这么久,一直都是享受着各位大侠们总结的智慧的果实,自己也应该贡献一点点自己的力量,从今天开始将学习到的点点滴滴通过blog记录下来,希望能对一些致力于ASP.NET开发的朋友有些许帮助,那就是我最大的欣慰。就以Discuz!NT的研究作为一个开始吧。

      先说说在ASP.NET中的控件在浏览器与服务器传递数据时仍可以保留用户输入的内容(或者说是状态)是因为这些数据(状态)通过VIEWSTATE保存了,关于这方面的具体介绍请参看Dixin《理解ASP.NET中的ViewState》

      Discuz!NT的返回实现中没有采用ASP.NET的默认的保存页面数据(状态)的方式,而是通过以参数形式传递,下面就看看其代码实现

         Discuz.Web.login.aspx.cs

    代码
    StringBuilder builder = new StringBuilder();
    foreach (string key in System.Web.HttpContext.Current.Request.QueryString.AllKeys)
    {
    if (key != "postusername")
    {
    builder.Append(
    "&");
    builder.Append(key);
    builder.Append(
    "=");
    builder.Append(DNTRequest.GetQueryString(key));
    }
    }
    base.SetBackLink("login.aspx?postusername=" + Utils.UrlEncode(DNTRequest.GetString("username")) + builder.ToString())

    这里的base.SetBackLink是在Discuz.Forum.PageBase.cs

    代码
    /// <summary>
    /// 回退链接的内容
    /// </summary>
    protected internal string msgbox_backlink = "javascript:history.back();";

    /// <summary>
    /// 设置回退链接的内容
    /// </summary>
    /// <param name="strback">回退链接的内容</param>
    public void SetBackLink(string strback)
    {
    msgbox_backlink
    = strback;
    }

    这样,在输出错误等情况出现后,如果点击返回上一页按钮,将会把此前保留状态恢复

     

  • 相关阅读:
    case when then else end
    spark读文件写入mysql(scala版本)
    mysql语句
    spark读文件写mysql(java版)
    spark的广播变量
    hive,把一个表中计算好的数据,存到另一个外部表中
    spark操作hive方式(scala)
    spark sql启动优化
    hive on spark (spark2.0.0 hive2.3.3)
    hive优化,开启压缩功能
  • 原文地址:https://www.cnblogs.com/Excellent/p/1383203.html
Copyright © 2020-2023  润新知