天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Asp.net 菜單控件簡潔版

本文介紹的菜單控件采用的css 和ul list來顯示菜單,生成的html小,無需Javascript支持,對大部分的瀏覽器都支持,除ie6要單獨修改css也可以使其支持。
通過本文可以了解ASP.NET 控件的開發,及Composite設計模式的實際運用。
采用Composite設計模式設計菜單類:
MenuCompositeitem類
復制代碼 代碼如下:
namespace RuiNET.Controls
{
[Serializable()]
public class MenuCompositeItem
{
private List<MenuCompositeItem> _children = new List<MenuCompositeItem>();
private string _text;
private string _link;
private string _target;
/// <summary>
/// 菜單項
/// </summary>
/// <param name="text">菜單名</param>
/// <param name="link">鏈接</param>
public MenuCompositeItem(string text, string link)
{
this._text = text;
this._link = link;
}
/// <summary>
/// 菜單項
/// </summary>
/// <param name="text">菜單名</param>
/// <param name="link">鏈接</param>
/// <param name="target">跳轉目標</param>
public MenuCompositeItem(string text, string link, string target)
{
this._text = text;
this._link = link;
this._target = target;
}
/// <summary>
/// 設置或獲取菜單名
/// </summary>
public string Text
{
get { return _text; }
set { _text = value; }
}
/// <summary>
/// 設置或獲取鏈接
/// </summary>
public string Link
{
get { return _link; }
set { _link = value; }
}
/// <summary>
/// 跳轉目標
/// </summary>
public string Target
{
get { return _target; }
set { _target=value; }
}
/// <summary>
/// 設置或獲取子菜單
/// </summary>
public List<MenuCompositeItem> Children
{
get { return _children; }
set { _children = value; }
}
}

MenuComposite類
復制代碼 代碼如下:
namespace RuiNET.Controls
{
[DefaultProperty("Menu")]
[ToolboxData("<{0}:MenuComposite runat=server></{0}:MenuComposite>")]
public class MenuComposite : WebControl
{
/// <summary>
/// 設置獲取選擇的菜單
/// </summary>
[Bindable(true)]
[DefaultValue("")]
[Localizable(true)]
public string SelectedMenuText
{
get
{
String s = (String)ViewState["SelectedMenuText"];
return ((s == null) ? String.Empty : s);
}
set
{
ViewState["SelectedMenuText"] = value;
}
}
/// <summary>
/// 獲取和設置菜單項從ViewState
/// </summary>
[Bindable(true)]
[DefaultValue(null)]
[Localizable(true)]
public MenuCompositeItem MenuItems
{
get
{
return ViewState["MenuItems"] as MenuCompositeItem;
}
set
{
ViewState["MenuItems"] = value;
}
}
/// <summary>
/// 呈現菜單結構
/// </summary>
/// <param name="output">HTML輸出流</param>
protected override void RenderContents(HtmlTextWriter output)
{
MenuCompositeItem root = this.MenuItems;
output.Write(@"<div class=""navmenu"">");
output.Write(@" <ul>");
for (int i = 0; i < root.Children.Count; i++)
{
RecursiveRender(output, root.Children[i]);
}
output.Write(@" </ul>");
output.Write(@"</div>");
}
/// <summary>
/// 遞歸輸出菜單項
/// </summary>
/// <param name="output">HTML輸出流</param>
/// <param name="item">菜單項.</param>
/// <param name="depth">Indentation depth.</param>
private void RecursiveRender(HtmlTextWriter output, MenuCompositeItem item)
{
output.Write("<li>");
if (string.IsNullOrEmpty(item.Target))//為空不設置跳轉目標
{
output.Write(@"<a href=""" + item.Link + @""">");
}
else
{
output.Write(@"<a href=""" + item.Link + @""" target= """ + item.Target + @""">");
}
if (item.Text == SelectedMenuText) //選中的菜單
{
output.Write(@"<span class=""selected"">");
output.WriteLine(item.Text);
output.WriteLine("</span>");
}
else
{
output.Write(item.Text);
}
output.Write("</a>");
if (item.Children.Count > 0)
{
output.WriteLine();
output.Write("<ul>");
for (int i = 0; i < item.Children.Count; i++)
{
RecursiveRender(output, item.Children[i]);
}
output.Write("</ul>");
}
output.Write("</li>");
}
}
}

在頁面中使用
添加對控件的引用后就可以直接在“工具箱”-》Controls組件中 看到MenuComposite組件
再就可以像其他ASP.NET 控件一樣使用
使用:
復制代碼 代碼如下:
MenuCompositeItem root = new MenuCompositeItem("root", null);
MenuCompositeItem menu01 = new MenuCompositeItem("menu01", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu02 = new MenuCompositeItem("menu02", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu03 = new MenuCompositeItem("menu03", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu04 = new MenuCompositeItem("menu04", ResolveUrl("~/Page04.ASPx"));
MenuCompositeItem menu05 = new MenuCompositeItem("menu05", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu01_01 = new MenuCompositeItem("menu01-01", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu01_02 = new MenuCompositeItem("menu01-02", ResolveUrl("~/Page01-02.ASPx"));
MenuCompositeItem menu01_03 = new MenuCompositeItem("menu01-03", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu01_04 = new MenuCompositeItem("menu01-04", ResolveUrl("~/Default.ASPx"));
menu01.Children.Add(menu01_01);
menu01.Children.Add(menu01_02);
menu01.Children.Add(menu01_03);
menu01.Children.Add(menu01_04);

MenuCompositeItem menu02_01 = new MenuCompositeItem("menu02-01", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu02_02 = new MenuCompositeItem("menu02-02", ResolveUrl("~/Default.ASPx"), "menu02-02");
menu02.Children.Add(menu02_01);
menu02.Children.Add(menu02_02);

MenuCompositeItem menu04_01 = new MenuCompositeItem("menu04-01", ResolveUrl("~/Default.ASPx"));
MenuCompositeItem menu04_02 = new MenuCompositeItem("menu04-02", ResolveUrl("~/Page04-02.ASPx"), "_blank");
menu04.Children.Add(menu04_01);
menu04.Children.Add(menu04_02);
root.Children.Add(menu01);
root.Children.Add(menu02);
root.Children.Add(menu03);
root.Children.Add(menu04);
root.Children.Add(menu05);

TheMenuComposite.MenuItems = root;
此時生成的編譯運行后會生成一個沒有樣式Ul list ,效果如下:
  
因此要生成可顯示和隱藏的菜單項,關鍵在css的設置上,開始時將二級子菜單設置為隱藏visibility: hidden;
同時定義li的hover事件,li:hover時:自菜單的 visibility要改為visible; 大致原理是這樣,當然還有注意菜單項的位置
一級菜單float:left;使其能水平顯示。
CSS定義如下:
復制代碼 代碼如下:
.navmenu *
{
margin: 0;
padding: 0;
}
.navmenu
{
border: #000 1px solid;
height: 25px;
}
.navmenu li
{
/*水平菜單*/
float: left;
list-style: none;
position: relative;
}
.navmenu a
{
display: block;
font-size: 12px;
height: 24px;
width: 100px;
line-height: 24px;
background-color: #CDEB8B;
color: #0000ff;
text-decoration: none;
text-align: center;
border-left: #36393D 1px inset;
border-right: #36393D 1px inset;
border-bottom: #36393D 1px inset;
}
/*單獨設置一級菜單樣式*/
.navmenu > ul > li > a
{
font-size: 11px;
font-weight: bold;
}
.navmenu a:hover
{
background: #369;
color: #fff;
}
/*新增的二級菜單部分*/
.navmenu ul ul
{
visibility: hidden; /*開始時是隱藏的*/
position: absolute;
left: 0px;
top: 24px;
}
.navmenu ul li:hover ul, .navmenu ul a:hover ul
{
visibility: visible;
}
.navmenu ul ul li
{
clear: both; /*垂直顯示*/
text-align: left;
}
/*選中菜單項*/
.navmenu .selected
{
padding-left:15px;
background-position-x:0px;
background-image: url(./res/selected.gif);
background-repeat: no-repeat;
text-decoration:underline;
}

定義CSS后的效果如下:

到此菜單控件已完成。已測試過可以在IE7,IE8,Chrome,Firefox中正常顯示,在IE6顯示可能會有問題,可以參考純CSS多級菜單 進行修改,

本文的CSS顯示部分參考了此文的介紹。

附上完整代碼,如需要可自行下載修改 下載文件

AspNet技術Asp.net 菜單控件簡潔版,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 恋夜影视列表免费安卓手机版 | 日日夜夜国产 | 91精选国产| 国产成人在线视频网站 | 高中生高潮抽搐喷出白浆视频 | 老汉老太bbbbbxxxxx | 99国产精品免费视频 | 中文字幕一区二区三区在线播放 | 免费韩国伦理2017最新 | 色欲久久精品AV无码 | WWW夜片内射视频在观看视频 | 欧美成人免费一区二区三区不卡 | 国产精品高清视亚洲一区二区 | 国产精品麻豆高潮刺激A片 国产精品麻豆a在线播放 | 偷柏自拍亚洲综合在线 | 国产欧美一区二区精品仙草咪 | 暖暖的视频完整视频免费韩国 | 9999精品视频| 国产亚洲精品久久久久久白晶晶 | 国际老妇高清在线观看 | 97人人爽人人爽人人人片AV | 在线 无码 中文 强 乱 | 啪啪漫画无遮挡全彩h网站 啪啪漫画无遮挡全彩h同人 | 给我免费播放片bd国语 | 老牛天天晚上夜噜噜噜 | 在公交车上被JB草坏了被轮J了 | 国产精品嫩草影院在线观看免费 | 久久精品麻豆国产天美传媒果冻 | 视频成人永久免费视频 | 一区不卡二区卡 | 越南女 黑人 痛苦 大叫 | 欧美日本韩国一二区视频 | 青青青青久久久久国产的 | 日本高清不卡码无码v亚洲 日本福利片午夜免费观着 日本粉嫩学生毛绒绒 | 国产精品一区二区免费 | 国产成人免费手机在线观看视频 | 男生射女生 | 伊人久久大香线蕉综合网站 | 暖暖 视频 免费 高清 在线观看 | 亚洲国产精品无码中文字满 | 国产精品永久免费 |