|
網(wǎng)址其實(shí)就是目錄文件的影射。因此只要拆分URL,并且根據(jù)URL的層級關(guān)系進(jìn)行循環(huán),就可以得到當(dāng)前導(dǎo)航文件的目錄。
1、建立數(shù)據(jù)庫表:Navigate
列名 | 數(shù)據(jù)類型 | 說明 |
id | int | |
parentId | int | 父ID |
root | int | 層級,0代表根目錄,最頂層 |
pathName | varchar(50) | (URL)路徑名稱 |
navName | varchar(50) | (欄目)導(dǎo)航名稱 |
2、建立用戶控件 navigate.ascx
-----------------------------------------------------------
<%@ Control Language="C#" AutoEventWireup="true" CodeFile="Navigate.ascx.cs" Inherits="UC_Navigate" %>
<div style="display:block;margin-top:5px;margin-left:3px;margin-bottom:5px;">
您當(dāng)前的位置:<a href="/index.ASPx">首頁</a>
>>
<ASP:Label ID="lblNavigate" runat="server"></ASP:Label>
<ASP:Label ID="lblTitle" runat="server"></ASP:Label>
</div>
3、用戶控件的CS后臺文件 navigate.ascx.cs
-----------------------------------------------------------
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Configuration;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using Bai51.Data;
public partial class UC_Navigate : System.Web.UI.UserControl
{
private string localUrl="http://localhost:8085";
private string title;
private DataSet ds;
private DataTable dt;
protected void Page_Load(object sender, EventArgs e)
{
#region -- 獲取導(dǎo)航信息表內(nèi)容(緩存) --
ds=(DataSet)Cache["dsNavigateCache"];
if(ds==null)
{
ds=SqlComd.CreateSqlDataSet("select * from navigate","dsNavigate");
Cache.Insert("dsNavigateCache",ds,null,System.Web.Caching.Cache.NoAbsoluteExpiration,TimeSpan.FromHours(24));
}
dt=ds.Tables[0];
#endregion
#region -- 生成導(dǎo)航信息 --
//分割當(dāng)前URL地址
string[] webUrl = System.Web.HttpContext.Current.Request.Path.Split(new char[] { '/' });
int len = webUrl.Length - 1;
//層級循環(huán)
string strUrl = localUrl + "/";
string strNavigate = "";
string parenId = "0";
for (int i = 1; i < len; i++)
{
string sql = "root=" + Convert.ToString(i-1) + " and pathName='" + webUrl[i] + "' and parentId=" + parenId;
DataRow[] rows = dt.Select(sql);
//循環(huán)連接地址
strUrl += (webUrl[i] + "/");
strNavigate += "<a href='" + strUrl + "'>" + rows[0]["navName"].ToString() + "</a>" + " >> ";
//保存父ID
parenId = rows[0]["Id"].ToString();
}
#endregion
lblNavigate.Text=strNavigate;
lblTitle.Text=title ;
}
#region --控件屬性 --
public string LocalUrl
{
get{return localUrl;}
set{ localUrl=value ;}
}
public string Title
{
get { return title; }
set { title = value; }
}
#endregion
}
4、使用方法
-----------------------------------------------------------
在頁面中拖入 Navigate.ascx 用戶控件,命名為"navBar"。
在后臺代碼中寫入當(dāng)前文件的導(dǎo)航名稱即可。
navBar.Title = "本頁面是XX欄目";
AspNet技術(shù):使用UserControl做網(wǎng)站導(dǎo)航條的思路 分析,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。