• IsPostback的原理


    ispostback:就是判断页面是首次加载的,还是数据回发(有get或者post请求过的)后的页面。上代码吧,直观点。


    1.asp.net页面


    复制代码
    <body>
        <form id="form1" runat="server">
        <div>
            <asp:Button ID="Button1" runat="server" Text="Button" />
        </div>
        </form>
    </body>
    复制代码
    复制代码
     protected void Page_Load(object sender, EventArgs e)
            {
                if (IsPostBack)
                {
                    Response.Write("这是回发后的页面!"); //点击button1控件后出现这个
                }
                else
                {
                    Response.Write("这是首次加载的页面!"); //第一次预览出现这个
                }
            }
    复制代码

    2.html页面


    (1)由于是纯粹的html页面,即便点击提交也无法,回发数据,也就是html页面无法获取回发过来的值。所以ispostback为false。


    <form action="WebForm1.aspx" method="post">
    <input id="Submit1" type="submit" value="submit" />
    </form>
    复制代码
    protected void Page_Load(object sender, EventArgs e)
            {
                if (IsPostBack)
                {
                    Response.Write("这是回发后的页面!"); 
                }
                else
                {
                    Response.Write("这是首次加载的页面!"); //第一次预览出现这个,点击submit控件后还出现这个
                }
            }
    复制代码

    (2)这里加了一个隐藏的viewstate,回发过来的数据存放在viewstate,完成了数据回发,ispostback的值也就为true。如果你疑惑如果下次还想要首次加载的数据怎么办,我告诉你,下次读取数据直接从viewstate中读取,不用再次发出请求。


    <form action="WebForm1.aspx" method="post">
    <input type="hidden" name="__viewstate" />
    <input id="Submit1" type="submit" value="submit" />
    </form>
    复制代码
     protected void Page_Load(object sender, EventArgs e)
            {
                if (IsPostBack)
                {
                    Response.Write("这是回发后的页面!"); //点击submit控件后又出现这个。
                }
                else
                {
                    Response.Write("这是首次加载的页面!"); //第一次预览出现这个。
                }
            }
    复制代码

    小结:其是asp.net页面中也有一个隐藏的viewstate字段,通过在页面上查看源代码就能看出来,一般为了减少服务器的压力,我们通常会把viewstate禁用掉,那么将不会用到ispostback判断是否是数据回发过的页面,那将每次执行以下后台代码,如果是读取数据库中的数据,那么也将每次都要读取一下,这里你可能会担心数据库的压力过大,这里我们还有另外的解决办法,而并非使用viewstate,那就是使用缓存技术解决这里的问题。

  • 相关阅读:
    在 kylin-v10环境中搭建 electron
    二叉树建树
    python 从txt文件中提取数据保存到 xlxs 文件中
    openpyxl 插件写入数据
    python时间格式转换
    vue-typescript-element-template使用总结
    vue3入门
    typescript入门
    记录下谷歌 浏览器请求数据时遇302,重新连接的问题
    uni使用render.js视图层与逻辑层传数据 的问题
  • 原文地址:https://www.cnblogs.com/weihengblogs/p/4396250.html
Copyright © 2020-2023  润新知