从Menustrip Winfoms隐藏一些菜单



我的窗口表单应用程序中有一个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;
     }
}

相关内容

  • 没有找到相关文章

最新更新