无敌龙书屋,怎么保存茶叶,惊呆!陈晓大光头太抢镜
网址其实就是目录文件的影射。因此只要拆分url,并且根据url的层级关系进行循环,就可以得到当前导航文件的目录。
1、建立数据库表:navigate
列名 | 数据类型 | 说明 |
id | int | |
parentid | int | 父id |
root | int | 层级,0代表根目录,最顶层 |
pathname | varchar(50) | (url)路径名称 |
navname | varchar(50) | (栏目)导航名称 |
using bai51.data;
public partial class uc_navigate : system.web.ui.usercontrol
{
private string localurl="";
private string title;
private dataset ds;
private datatable dt;
protected void page_load(object sender, eventargs e)
{
#region -- 获取导航信息表内容(缓存) --
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 -- 生成导航信息 --
//分割当前url地址
string[] weburl = system.web.httpcontext.current.request.path.split(new char[] { '/' });
int len = weburl.length - 1;
//层级循环
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);
//循环连接地址
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"。
在后台代码中写入当前文件的导航名称即可。
navbar.title = "本页面是xx栏目";
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
Net Core Web Api项目与在NginX下发布的方法
asp.net core3.1 引用的元包dll版本兼容性问题解决方案
IdentityServer4实现.Net Core API接口权限认证(快速入门)
ASP.NET Core MVC通过IViewLocationExpander扩展视图搜索路径的实现
网友评论