Winform如何进行左边菜单栏,右边内容的设计

1.新建winform项目。

 

2.添加工具splitContainer

 

3.在panel1中添加listview,并动态加载菜单

 

你可以设置splitContainer的SplitterDistance大小来控制panel1的大小,调整你觉得合适的左菜单栏大小。接下来就是为listview添加菜单绑定。(listview的view属性一定要设置成Details,MultiSelect一定低要设置成false,FullRowSelect设置为true

在form的load事件里边添加如下代码:

 private void Form1_Load(object sender, EventArgs e)
        {
            ImageList image = new ImageList();
            image.ImageSize = new Size(1, 35);//设置每次点击view时以图片的形式
            ColumnHeader ch = new ColumnHeader();
            ch.Text = "菜单";
            ch.Width = splitContainer1.Panel1.Width;
            ch.TextAlign = HorizontalAlignment.Center;
            listView1.Columns.Add(ch);//设置listview的列名,没啥用处
            listView1.SmallImageList = image;//设置每个view的显示形式
            LoadList();//加载一级栏目
            listView1.Width = ch.Width;//设置每个view的宽度都一致
            listView1.Items[0].BackColor = Color.LightGray;//设置主页的选中后的颜色
            //启动首先展示主页
            splitContainer1.Panel2.Controls.Clear();//每次执行时清空panel2
            主页 主页 = new 主页();
            主页.Parent = splitContainer1.Panel2;
            主页.Dock = DockStyle.Fill;//设置用户控件充满panel2
            主页.Show();
        }
        /// <summary>
        /// 一级菜单
        /// </summary>
        private void LoadList()
        {
            listView1.Items.Clear();//清空菜单
            //添加菜单
            ListViewItem 主页 = new ListViewItem("     主页");
            ListViewItem 菜单一 = new ListViewItem("     菜单一");
            ListViewItem 菜单二 = new ListViewItem("     菜单二");
            ListViewItem 菜单三 = new ListViewItem("     菜单三");
            ListViewItem 重启 = new ListViewItem("     重启");
            listView1.Items.Add(主页);
            listView1.Items.Add(菜单一);
            listView1.Items.Add(菜单二);
            listView1.Items.Add(菜单三);
            listView1.Items.Add(重启);
        }
        /// <summary>
        /// 二级菜单
        /// </summary>
        private void ChildList()
        {
            listView1.Items.Clear();//清空菜单
            //添加菜单
            ListViewItem 二级菜单一 = new ListViewItem("     二级菜单一");
            ListViewItem 二级菜单二 = new ListViewItem("     二级菜单二");
            ListViewItem 返回 = new ListViewItem("     返回");
            listView1.Items.Add(二级菜单一);
            listView1.Items.Add(二级菜单二);
            listView1.Items.Add(返回);
        }
        /// <summary>
        /// listview的鼠标单击事件
        /// </summary>
        /// <param name="sender"></param>
        /// <param name="e"></param>
        private void listView1_MouseClick(object sender, MouseEventArgs e)
        {
            foreach (ListViewItem item in listView1.Items)
            {
                item.BackColor = Color.WhiteSmoke;//遍历每个菜单栏的颜色
            }
            if (e.Button == MouseButtons.Left)
            {
                if (listView1.SelectedItems.Count > 0)
                {
                    listView1.Items[listView1.FocusedItem.Index].BackColor = Color.LightGray;//设置选中菜单栏的颜色
                    string choose = listView1.Items[listView1.FocusedItem.Index].Text;//选中菜单栏的文本
                    ChangePlanel(choose.Trim());//根据文本名称进行相应的展示
                }
            }
        }
        /// <summary>
        /// 根据文本名称进行相应的展示
        /// </summary>
        /// <param name="name"></param>
        private void ChangePlanel(string name)
        {
            switch (name)
            {
                case "主页":
                    splitContainer1.Panel2.Controls.Clear();
                    主页 zhuye = new 主页();
                    zhuye.Parent = splitContainer1.Panel2;
                    zhuye.Dock = DockStyle.Fill;
                    zhuye.Show();
                    break;
                case "菜单一":
                    splitContainer1.Panel2.Controls.Clear();
                    主菜单1 zhu1 = new 主菜单1();
                    zhu1.Parent = splitContainer1.Panel2;
                    zhu1.Dock = DockStyle.Fill;
                    zhu1.Show();
                    break;
                case "菜单二":
                    ChildList();
                    break;
                case "菜单三":
                    splitContainer1.Panel2.Controls.Clear();
                    主菜单3 zhu3 = new 主菜单3();
                    zhu3.Parent = splitContainer1.Panel2;
                    zhu3.Dock = DockStyle.Fill;
                    zhu3.Show();
                    break;
                case "二级菜单一":
                    splitContainer1.Panel2.Controls.Clear();
                    二级菜单1 er1 = new 二级菜单1();
                    er1.Parent = splitContainer1.Panel2;
                    er1.Dock = DockStyle.Fill;
                    er1.Show();
                    break;
                case "二级菜单二":
                    splitContainer1.Panel2.Controls.Clear();
                    二级菜单2 er2 = new 二级菜单2();
                    er2.Parent = splitContainer1.Panel2;
                    er2.Dock = DockStyle.Fill;
                    er2.Show();
                    break;
                case "返回":
                    LoadList();
                    break;
                case "重启":
                    try
                    {
                        Application.Restart();
                    }
                    catch (Exception)
                    {
                        System.Environment.Exit(0);
                    }
                    break;
            }
        }

我好多控件的名称命名都是中文,只是为了大家方便看,自己写时千万不要这样啊!!!

以下就是效果图

 

项目源代码下载地址:https://sizeinqi.lanzoui.com/i9x575e

当你在使用Maven集成MyBatis-Plus时遇到这个错误,它通常意味着MyBatis无法找到你指定的Mapper接口的映射方法。在这个例子中,`com.hlw.yx.mapper.GasClientMapper.getinfo`是一个无效的bound statement,也就是找不到对应的SQL语句。 解决这个问题的步骤包括: 1. **检查Mapper接口**:确认`GasClientMapper`接口是否存在,并且其中是否有一个名为`getinfo`的方法。如果方法名拼写错误、大小写不符或者注解配置有误,MyBatis都不会识别。 ```java // 示例Mapper接口 public interface GasClientMapper { ResultInfo getinfo(@Param("id") Long id); // 确保方法名和参数匹配 } ``` 2. **Mapper XML配置文件**:在`src/main/resources/mapper`目录下的相应XML文件(例如`GasClientMapper.xml`)中,确认`getinfo`方法是否有正确的映射配置。比如,如果有动态SQL,需要确保SQL语句语法正确。 ```xml <mapper namespace="com.hlw.yx.mapper.GasClientMapper"> <select id="getinfo" resultType="com.example.ResultInfo"> SELECT * FROM table_name WHERE id = #{id} </select> </mapper> ``` 3. **路径和命名空间**:检查Mapper的namespace是否与实际包名一致。如果Mapper的位置或名称改变,记得更新Mapper XML的namespace属性。 4. **别名或者全限定名**:确认你在代码中引用Mapper时使用的全限定名是否正确,有时候可能会因为工程结构更改而引入了混淆。 5. **重启项目**:有时候可能是缓存的问题,尝试清理Maven项目的本地仓库并重新构建。 如果你已经检查过以上所有地方还是出现问题,可能需要查看具体的错误堆栈信息来获取更详细的错误原因。
评论 76
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值