奇怪,页面的 OnLoad 方法会执行 2 次!

shove 2009-01-10 10:26:32
一、PageBase.cs:

public class PageBase : System.Web.UI.Page
{
protected override void OnLoad(EventArgs e)
{
using (FileStream fs = new FileStream("e:\\aaaa.txt", FileMode.Append, FileAccess.Write, FileShare.Write))
{
StreamWriter writer = new StreamWriter(fs, System.Text.Encoding.GetEncoding("GBK"));

writer.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + ":" + System.DateTime.Now.Millisecond.ToString() + "\t\t" + "aaaaaaaaaaaaaaaaa1" + "\r\n");

writer.Close();
}
}
}

二、Default.aspx.cs:

public partial class _Default : PageBase
{
protected void Page_Load(object sender, EventArgs e)
{
}
}


一个简单的页面继承。
这样写,打开网页,文本文件被增加一条记录,正常。刷新一下后,又增加一条,也正常。

-----------------------------------------------------------------------
但是: 当把以上基类单独放到一个项目中,编译成 .dll,再包含到网站,情况就不同了。

一打开网页,就运行了 2 次,文本文件中被增加 2 条记录,刷新一下页面,又增加 2 次。

很是奇怪。

哪位大侠把机制讲解一下。
...全文
1177 44 打赏 收藏 转发到动态 举报
写回复
用AI写文章
44 条回复
切换为时间正序
请发表友善的回复…
发表回复
tonykam 2011-04-22
  • 打赏
  • 举报
回复
天啊,原来是这样,感激不尽,我为这个问题郁闷了好久。
shove 2009-01-15
  • 打赏
  • 举报
回复
罪魁祸首是:

<img src="" .... />

当页面上出现了 src="" 空串时,
Page_Load、 OnLoad、 Init 等等都执行 2 次。

我上面说的那个控件中出现了这个,所以导致执行 2 次。

而该Web自定义用户控件如果不重写 Render, 用自己默认的方法,就不会。

--------------------------------------------------

总之, <img src="" 换为 <img src="about:blank" 就没有任何问题了。
shove 2009-01-14
  • 打赏
  • 举报
回复
为了不给大家造成误导,特修正我自己在 41 楼的错误:

1、经晚上仔细研究,不是 Ajax 执行了一次 OnLoad
2、是页面上的自定义用户控件造成的。

现象:Web自定义用户控件,如果不重写 Render 方法,则不会造成 OnLoad 2 次执行,如果 protected override void Render(HtmlTextWriter output) 改写这个方法,则会造成 OnLoad 2 次执行。
与 IsPostBack 无关。
shove 2009-01-13
  • 打赏
  • 举报
回复
谢谢各位,问题解决:

页面上有一个用户控件,用户控件使用了 Ajax。

Ajax 执行了一次页面的 OnLoad。
cwmwss 2009-01-12
  • 打赏
  • 举报
回复
学习
钊xsun 2009-01-12
  • 打赏
  • 举报
回复
[Quote=引用楼主 shove 的帖子:]
一、PageBase.cs:

public class PageBase : System.Web.UI.Page
{
protected override void OnLoad(EventArgs e)
{
using (FileStream fs = new FileStream("e:\\aaaa.txt", FileMode.Append, FileAccess.Write, FileShare.Write))
{
StreamWriter writer = new StreamWriter(fs, System.Text.Encoding.GetEncoding("GBK"));

writer.WriteLine(System.Date…
[/Quote]
你在pagebase.cs类里重载了onload的方法,当然是执行了两次了。
页面刚打开时是先执行类里的,然后再执行page_onload里的。你调试下就知道了
一弗楚 2009-01-11
  • 打赏
  • 举报
回复
up
shove 2009-01-11
  • 打赏
  • 举报
回复
谢谢大家。

sp1234 大侠,不好意思,我的代码不是复制粘贴过来的,是在 CSDN 上敲的(因为省去了一些东西)。
原文有 base.OnLoad(e);

----------------------------------------

我现在怀疑是 Ajax 运行了一次 OnLoad.
因为页面上有 Ajax 的东西。
NaNorth 2009-01-11
  • 打赏
  • 举报
回复
用 Page.IsPostBack 是很靠谱的
阿彪兄 2009-01-10
  • 打赏
  • 举报
回复
支持一下
kimmking 2009-01-10
  • 打赏
  • 举报
回复
各楼的还都不行的话,楼主可以保存开发环境和示例,
给asp.net开发组报一个bug了。
kimmking 2009-01-10
  • 打赏
  • 举报
回复
1、检查设计器里的代码,是不是注册了两次
2、清空vs的缓存,清理,重新编译,运行


还不行的话,没办法了,
当年,慕白兄和思归都没搞定:
http://topic.csdn.net/t/20041210/15/3634069.html
shove 2009-01-10
  • 打赏
  • 举报
回复
楼上改了哪里啊,没看到
walkghost 2009-01-10
  • 打赏
  • 举报
回复
有事件回发吧?
每次回发都会执行page_load。
zzxap 2009-01-10
  • 打赏
  • 举报
回复
改成这样

public class PageBase : System.Web.UI.Page
{
protected override void OnLoad(EventArgs e)
{
if(!Page.IsPostBack)
{
using (FileStream fs = new FileStream("e:\\aaaa.txt", FileMode.Append, FileAccess.Write, FileShare.Write))
{
StreamWriter writer = new StreamWriter(fs, System.Text.Encoding.GetEncoding("GBK"));

writer.WriteLine(System.DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss") + ":" + System.DateTime.Now.Millisecond.ToString() + "\t\t" + "aaaaaaaaaaaaaaaaa1" + "\r\n");

writer.Close();
}
}
}
}

liberpc 2009-01-10
  • 打赏
  • 举报
回复
学习了
孟子E章 2009-01-10
  • 打赏
  • 举报
回复
protected override void OnLoad(EventArgs e)
{
base.OnLoad(e);


autoeventWireup ="false"

试试
shove 2009-01-10
  • 打赏
  • 举报
回复
找到的帖子是:

http://topic.csdn.net/t/20041210/15/3634069.html
shove 2009-01-10
  • 打赏
  • 举报
回复
在 CSDN 上找到一个 2004 年的帖子,

但是问题还是没有解决。我的问题与这个基本一样。

绝对不是 IsPostBack, 这个是很基本的。
mengxj85 2009-01-10
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 kongwei521 的回复:]
if(IsPostBack)
{
这是点击事件执行
}
else
{
这个里头是 页面第一次加载 执行的呀。
}
[/Quote]
Up
如此
加载更多回复(24)

62,269

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧