又有一个问题,很经典。

ritiande 2008-05-27 12:05:16
if(Session["status"]!=null)
if(Session["status"].ToString()=="超级管理员")
{
this.dg.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.dg_DeleteCommand);//注册删除事件
dg.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler( this.dg_ItemDataBound );//注册绑定事件
}
else
{
dg.Columns[5].Visible=false;//隐藏删除列
dg.Columns[3].Visible=false;//隐藏身份列
}

当管理员身份为普通管理员进入后,删除列不见了,身份列(模板列)不见了。
问题出来了,点击更新后,原以为ok了,但第二次以用同样的账号进入不了啊,用超级管理员身份进入后,尽然是该账号的身份变为空了,郁闷了。
哪位高手帮个忙啊,在线等,谢了。
...全文
85 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
hecong875 2008-05-27
  • 打赏
  • 举报
回复
这样看不出来什么的!最好打个断点自己跟下把! 特别的登陆那里!
ritiande 2008-05-27
  • 打赏
  • 举报
回复
哎呀,我的错
private void InitializeComponent()
{
this.dg.CancelCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.dg_CancelCommand);
this.dg.EditCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.dg_EditCommand);
this.dg.UpdateCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.dg_UpdateCommand);
if(Session["status"]!=null)
if(Session["status"].ToString()=="超级管理员")
{//***超级管理员身份,嗯,没错,能删除*/
this.dg.DeleteCommand += new System.Web.UI.WebControls.DataGridCommandEventHandler(this.dg_DeleteCommand);
dg.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler( this.dg_ItemDataBound );//事件注册
}
else
{//***普通管理员身份,不能删除,但
dg.Columns[5].Visible=false;//隐藏删除列
dg.Columns[3].Visible=false;//隐藏身份列
//把它给搞忘记了啊*/
dg.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler( this.dg_ItemDataBound );
}
this.addbtn.Click += new System.EventHandler(this.addbtn_Click);
this.Load += new System.EventHandler(this.Page_Load);
}

这下就没问题了,不够细心。
ritiande 2008-05-27
  • 打赏
  • 举报
回复
我把page_load和datagridbind代码贴出来,帮忙再看看。
private void Page_Load(object sender, System.EventArgs e)
{
if(!Page.IsPostBack)
{
if(Session["adminid"]==null)
{
Response.Write("<script>window.open('logout.aspx','_parent')</script>");
}
else
this.databind();
}
}
//datagrid binding
private void databind()
{
string dbname=Server.MapPath(@"db\mydb.mdb");
OleDbConnection conn=new OleDbConnection("PROVIDER=Microsoft.Jet.OLEDB.4.0;DATA Source="+dbname);
string strsql;//初始化sql语句
string uid=Session["adminid"].ToString();//保存管理员账号
string status=Session["status"].ToString();//保存管理员类型
if(status=="超级管理员")
strsql="select * from adminTable";//sql语句
else
{
strsql="select * from adminTable where uid='"+uid+"'";
this.Panel1.Visible=false;
this.Label2.Text="温馨提示:普通管理员无权删除账号、更改身份!";
}
OleDbDataAdapter da=new OleDbDataAdapter(strsql,conn);
DataSet ds=new DataSet();
da.Fill(ds);
this.dg.DataSource=ds;
this.dg.DataKeyField="id";
this.dg.DataBind();
}
zdjray 2008-05-27
  • 打赏
  • 举报
回复
IsPostBack问题

是PostBack的话不要初始化数据
lilei9633 2008-05-27
  • 打赏
  • 举报
回复
if(!Page.IsPostBack)
{}

62,053

社区成员

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

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

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

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