我的窗口表单应用程序中有一个menustrip,其中包含menuitems。
我想检查某些条件并禁用Menustrip栏中的Menuitems的可见性。假设普通用户正在访问应用程序,那么某些benuitem将被隐藏,如果管理员用户访问应用程序,则所有benuitems都应可见。
这是我的代码(我不确定),它不起作用。
public Visite(string username)
{
InitializeComponent();
label1.Text = username;
using (SqlConnection con = new SqlConnection("Data Source=ADMIN-PC\SQLEXPRESS;Initial Catalog=timar;Integrated Security=True"))
{
con.Open();
bool UserIsAdmin = true;
using (SqlCommand cmd = new SqlCommand("select * from [User] where Role =@Role", con))
{
cmd.Parameters.AddWithValue("@Role", "Admin");
UserIsAdmin = (int)cmd.ExecuteScalar() > 0;
}
if (UserIsAdmin == false)
{
utilisateurToolStripMenuItem.Visible = false;
}
else
{
utilisateurToolStripMenuItem.Visible= true;
}
con.Close();
}
}
请帮忙。预先感谢。
您正在谈论问题中的可见性,但您的代码表示已启用。
这是两个完全不同的事情。
如果您坚持使用粘性,则应将utilisateurToolStripMenuItem.Visible
设置为false
尝试这个..
public Visite(string username)
{
InitializeComponent();
label1.Text = username;
using (SqlConnection con = new SqlConnection("Data Source=ADMIN-PC\SQLEXPRESS;Initial Catalog=timar;Integrated Security=True"))
{
con.Open();
bool UserIsAdmin = false;
using (SqlCommand cmd = new SqlCommand("select * from [User] where Role =@Role", con))
{
cmd.Parameters.AddWithValue("@Role", "Admin");
UserIsAdmin = (int)cmd.ExecuteScalar() > 0;
}
utilisateurToolStripMenuItem.Visible = UserIsAdmin;
}
}