使用RadControls的RadMenu控件开发系统菜单

使用RadControls的RadMenu控件开发系统菜单关于菜单这个话题我想应该是不讲则懂,所以本文不会多讲这些概念,则重关注RadControls控件中的RadMenu控件的使用,结合数据库来开发一个系统菜单。一、数据库设计这里我就使用Access作为示例数据库,详细见下图:表字段依次为:自动编号、菜单编码、菜单名称、请求地址、菜单上显示的图片地址、快捷键(RadMenu控件支持)、菜单顺序、菜单级限、是否为末级和父菜单编码。整个设计中…

大家好,又见面了,我是你们的朋友全栈君。

关于菜单这个话题我想应该是不讲则懂,所以本文不会多讲这些概念,则重关注RadControls控件中的RadMenu控件的使用,结合数据库来开发一个系统菜单。

一、数据库设计

这里我就使用Access作为示例数据库,详细见下图:
使用RadControls的RadMenu控件开发系统菜单

表字段依次为:自动编号、菜单编码、菜单名称、请求地址、菜单上显示的图片地址、快捷键(RadMenu控件支持)、菜单顺序、菜单级限、是否为末级和父菜单编码。 整个设计中主要以菜单编码作为关联依据。

二、注册控件及使用控件皮肤

我们可以将控件添加到工具箱直接拖拽到aspx页面上就OK,随后可以在html视图下看到如下注册命令:

<!–<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />–>
1
<%
@RegisterAssembly
=

RadMenu.Net2

Namespace
=

Telerik.WebControls

TagPrefix
=

rad


%>

要使用RadControls提供的皮肤功能很方便,从安装目录下将皮肤文件复制到项目中,然后在控件上直接选择所需要的皮肤就OK。下图为RadMenu选择皮肤截图:
使用RadControls的RadMenu控件开发系统菜单

三、编码实现读取数据

示例使用Access数据库,简单配置了几条数据,通过ADO.NET读出来这个很简单,这里就不多说。菜单下的子菜单,以及下一级子菜单,凡是菜单都有可能会有这种情况,这里递归生成就OK。相关代码如下:

<!–<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />–>
1
namespace
MenuDome

2
{


3

public

class
Menu

4
{


5

private

static

string
connectionString
=


Provider=Microsoft.jet.OLEDB.4.0;dataSource=



6

+
HttpContext.Current.Server.MapPath(
@”
App_Data/MenuDB.mdb

);

7


8

private
DataTableExecuteQuery(
string
cmdText)

9
{


10

using
(OleDbConnectionconn
=

new
OleDbConnection(connectionString))

11
{


12

using
(OleDbDataAdapteroda
=

new
OleDbDataAdapter(cmdText,conn))

13
{


14
DataSetds
=

new
DataSet();

15
oda.Fill(ds);

16

return
ds.Tables[
0
];

17
}

18
}

19
}

20


21

public
DataTableGetMenu()

22
{


23

string
sql
=


select*frommenuwheregrade=0

;

24

return
ExecuteQuery(sql);

25
}

26


27

public
DataTableGetMenuBySupCode(
string
supMenuCode)

28
{


29

string
sql
=


select*frommenuwheresupmenucode=’


+
supMenuCode
+




;

30

return
ExecuteQuery(sql);

31
}

32
}

33
}

四、生成菜单项的准备

菜单一般都是公用的(不考虑用户权限相关的控制),我们可以把它开发成为一个公共的部分。本示例使用母版页来做菜单,新建母版页:
使用RadControls的RadMenu控件开发系统菜单

在此母版页里加入RadMenu控件,并设置相应的皮肤就OK。如下代码块:

<!–<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />–>
1
<
body
>


2

<
form
id
=”form1″
runat
=”server”
>


3


4

<%

菜单开始

%>


5

<
rad:RadMenu
ID
=”SystemMenu”
runat
=”server”
Skin
=”Web20″
>


6

</
rad:RadMenu
>


7

<%

菜单结束

%>


8


9

<%

内容开始

%>


10

<
asp:ContentPlaceHolder
ID
=”CPH”
runat
=”server”
>


11


12

</
asp:ContentPlaceHolder
>


13

<%

内容结束

%>


14


15

</
form
>


16
</
body
>

五、根据数据库数据生成菜单项

现在就差最后一步了,根据数据库里读取的数据生成菜单项。由于菜单下会有子菜单情况,示例中将菜单项生成分两步来处理,详细见如下代码:

<!–<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />–>
1
使用RadControls的RadMenu控件开发系统菜单
private

void
InitMenu()

2
ExpandedBlockStart.gifContractedBlock.gif
使用RadControls的RadMenu控件开发系统菜单
{

3使用RadControls的RadMenu控件开发系统菜单//查询出菜单配置信息
4使用RadControls的RadMenu控件开发系统菜单DataTabledtMenu=menu.GetMenu();
5使用RadControls的RadMenu控件开发系统菜单
6使用RadControls的RadMenu控件开发系统菜单for(inti=0;i<dtMenu.Rows.Count;i++)
7ExpandedSubBlockStart.gifContractedSubBlock.gif使用RadControls的RadMenu控件开发系统菜单{

8使用RadControls的RadMenu控件开发系统菜单//Rad菜单项
9使用RadControls的RadMenu控件开发系统菜单RadMenuItemitem=newRadMenuItem();
10使用RadControls的RadMenu控件开发系统菜单
11使用RadControls的RadMenu控件开发系统菜单item.ID=dtMenu.Rows[i][Code].ToString();
12使用RadControls的RadMenu控件开发系统菜单item.Text=dtMenu.Rows[i][Name].ToString();
13使用RadControls的RadMenu控件开发系统菜单item.Value=dtMenu.Rows[i][Url].ToString();
14使用RadControls的RadMenu控件开发系统菜单item.AccessKey=dtMenu.Rows[i][ShortCut].ToString();
15使用RadControls的RadMenu控件开发系统菜单
16使用RadControls的RadMenu控件开发系统菜单this.SystemMenu.Items.Add(item);
17使用RadControls的RadMenu控件开发系统菜单
18使用RadControls的RadMenu控件开发系统菜单//菜建子菜单
19使用RadControls的RadMenu控件开发系统菜单InitSubMenu(item,dtMenu.Rows[i][Code].ToString());
20使用RadControls的RadMenu控件开发系统菜单}

21使用RadControls的RadMenu控件开发系统菜单}

除了上面的方法,还有一个构建子菜单的方法InitSubMenu(),如下代码块:

<!–<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />–>
1
private

void
InitSubMenu(RadMenuItemitem,
string
supMenuCode)

2
{


3
DataTabledtMenu
=
menu.GetMenuBySupCode(supMenuCode);

4


5

if
(dtMenu
!=

null
)

6
{


7

foreach
(DataRowdataRow
in
dtMenu.Rows)

8
{


9
RadMenuItemsubItem
=

new
RadMenuItem();

10


11
subItem.ID
=
dataRow[

ID

].ToString();

12
subItem.Text
=
dataRow[

Name

].ToString();

13
subItem.Value
=
dataRow[

Url

].ToString();

14
subItem.AccessKey
=
dataRow[

ShortCut

].ToString();

15


16
item.Items.Add(subItem);

17


18

if
(Convert.ToInt32(dataRow[

EndGrade

])
!=

1
)

19
{


20
InitSubMenu(subItem,Convert.ToString(dataRow[

Code

]));

21
}

22
}

23
}

24
}

六、展现RadMenu风采

通过上面一步步的开发,现在终于可以一览RadMenu的风采了。通过上面建立的母版页建立一内容页,直接运行内容页就可以看到效果了。示例中我使用了三种皮肤:Web2.0,WebBlue和Vista,下面是此三种皮肤的运行截图:

使用RadControls的RadMenu控件开发系统菜单

使用RadControls的RadMenu控件开发系统菜单

使用RadControls的RadMenu控件开发系统菜单

七、其他

出了皮肤是一大特色外,RadMenu还提供了很多客户端事件,我们利用这些API可以很方便在在客户端通过JavaScript动态的来创建、添加、删除菜单项,如下属性截图:
使用RadControls的RadMenu控件开发系统菜单
尤其是在AJAX普遍使用的今天,无刷新的应用开发越来越普遍,RadMenu为我们提供了比较完美的菜单解决方案。

本文就简单介绍于此,更多示例可以访问RadControls官方提供的在线Demo,希望本文对大家在菜单开发上可以起到一定的帮助。官方示例地址:http://demos.telerik.com/aspnet/Menu/Examples/Overview/DefaultCS.aspx

本文示例下载

注:原创文章欢迎转载,转载请注明出处。 出处:http://beniao.cnblogs.com/http://www.cnblogs.com/

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161981.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • RJ45 网线接口介绍

    RJ45接口通常用于数据传输,最常见的应用为网卡接口。  RJ45是各种不同接头的一种类型(例如:RJ11也是接头的一种类型,不过它是电话上用的);RJ45头根据线的排序不同,分为有两种,一种是橙白、橙、绿白、蓝、蓝白、绿、棕白、棕;另一种是绿白、绿、橙白、蓝、蓝白、橙、棕白、棕;因此使用RJ45接头的线也有两种即:直通线、交叉线。RJ45型网卡接口  10100basetxRJ

    2022年4月9日
    50
  • mac idea 2021.4.1 激活码_通用破解码

    mac idea 2021.4.1 激活码_通用破解码,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月17日
    40
  • 计算机软件师社会需求,java软件工程师的社会环境如何?「建议收藏」

    计算机软件师社会需求,java软件工程师的社会环境如何?「建议收藏」计算机专业成功的改变了很多人的命运,很多人选择计算机培训后拥有了很体面的工作,拥有了很高的工资待遇,整个人的生活水平方面了质的改变。所以越来越多的人希望可以学习计算机,而在专业选择的过程中,JAVA专业吸引到很多求学者的关注。在对JAVA这个专业了解的过程中,JAVA软件工程师的社会环境成为了很多求学者希望了解的内容,这样才能够对这个专业具有更加全面的了解。社会的地位引起关注从JAVA专业成功就业…

    2022年9月23日
    1
  • 一键安装nagios

    一键安装nagios

    2021年8月27日
    61
  • vs2010旗舰版_密钥

    vs2010旗舰版_密钥YCFHQ-9DWCY-DKV88-T2TMH-G7BHP

    2022年5月3日
    40
  • 对于三极管饱和状态的理解「建议收藏」

    对于三极管饱和状态的理解「建议收藏」对于三极管饱和状态的理解https://zhidao.baidu.com/question/172715750.html问题来源对于三极管饱和状态的理解三极管如工作在饱和状态也就是开的状态,那么就是双结正偏这是书上的解释我自己的理解是这样的:饱和状态和从放大状态转变过来的,极电结和发射结正偏是结果,而不是原因就是说,三极管首先工作在放大状态,极电结反偏,发射结正偏当基级电流增大时,一直增大到三极管的非线性区(这里指的是饱和区),注意,在这一瞬间偏置情况并未改变,也就是说依然是极电结反偏,

    2022年9月11日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号