页面中保存变量的问题

minwen9704135 2007-01-29 11:34:19
方法一:
private int FlowID;//窗体类变量
private void Page_Load(object sender, System.EventArgs e)
{
FlowID = Request.QueryString["FlowID"]!=null?Int32.Parse//(Request.QueryString["FlowID"].ToString()):0;
}
方法二
public void aa(){
ViewState["DocID"] = Convert.ToInt32(Request.QueryString["DocID"]);
}
请问哪个方式好?请说明下理由?谢谢
...全文
177 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
minwen9704135 2007-01-29
  • 打赏
  • 举报
回复
因为第一中方法 每次页面刷新都要Request.QueryString["DocID"];(不知道在性能上有什么损失)但是ViewState估计性能上会比方法一要好吧?但是我就是说不出来什么根据 所以请大虾门指点一二
minwen9704135 2007-01-29
  • 打赏
  • 举报
回复
eyuannet 
不会吧  你确认吗?我试了页面刷新以后还是可以得到这个值的
qianduo 2007-01-29
  • 打赏
  • 举报
回复
用ViewState比session要好
Masic_send 2007-01-29
  • 打赏
  • 举报
回复
up
SXC585 2007-01-29
  • 打赏
  • 举报
回复
最好还是用Session
eyuannet 2007-01-29
  • 打赏
  • 举报
回复
经过本人测试无论是方法一还是方法二页面刷新后或重定向到本页后数据都无法保存所以建议用
Session["DocID"] = Convert.ToInt32(Request.QueryString["DocID"]);
最好
minwen9704135 2007-01-29
  • 打赏
  • 举报
回复
方法二
public void aa(){
ViewState["DocID"] = Request.QueryString["DocID"];//不好意思应该这样的
}
Snowdust 2007-01-29
  • 打赏
  • 举报
回复
通常情况下应该选用方法二,另外方法二可以改成属性,调用起来就方便了
public int aa
{
get
{
if (ViewState["DocID"] != null)
{
return Convert.ToInt32(ViewState["DocID"]);
}
else
{
return -1;
}
}
set
{
ViewState["DocID"] = value;
}
}
yyw84 2007-01-29
  • 打赏
  • 举报
回复
如果需要页面刷新后变量的值还能使用,那就选用方式二,如果不需要则直接使用方式1,
另外难道方式二在使用的时候就不需要转成int了吗?
这两种方式根本就不对立,只能说方式二是方式一的补充
C5662601 2007-01-29
  • 打赏
  • 举报
回复
用个label保存应该没问题 label设置成不可见

62,054

社区成员

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

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

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

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