母版页 treeview控件 SiteMapPath控件 treeview数据库绑定模式
母版页的后缀名是.Master
可以把母版页当成一个页面 想让哪里是别的内容就可以 通过如下:
<asp:ContentPlaceHolder ID="ContentPlaceHolder1" runat="server">
</asp:ContentPlaceHolder>
//相当于占位符 想改哪里占据哪里!
如果要创建带母版页的Web窗体 右击新建项即可
同样的 我们可以在母版页中添加JQUERY的引用 这样我们就可以在子页面中写入工厂函数的代码
如果套用母版页,控件的ID值会发生变化
这是Html生成的代码
解决方案:
JavaScript: var obj = document.getelementbyid("<%Label1.ClientID%>");
Jquery: $('#<%Label1.ClientID%>')
TreeView 绑定 XML
需要XmlDataSource控件,再设置TextField,NavigateUrlField 属性
SiteMapPath 站点地图控件
我们可以把它放到母版页
这个控件只能绑定Xml 其文件路径在项目根目录 名称为Web.sitemap
<?xml version="1.0" encoding="utf-8" ?>
<siteMap xmlns="http://schemas.microsoft.com/AspNet/SiteMap-File-1.0" >
<siteMapNode url="/default.aspx" title="第三波书店" description="第三波书店">
<siteMapNode url="" title="第二章" description="" >
<siteMapNode url="/chp02/login.aspx" title="登录"></siteMapNode>
<siteMapNode url="/chp02/SessionLogin.aspx" title="Sesson学习"></siteMapNode>
</siteMapNode>
<siteMapNode url="" title="第四章" description="" >
<siteMapNode url="/chp04/webForm1.aspx" title="母版页一"></siteMapNode>
<siteMapNode url="/chp04/webForm2.aspx" title="母版页二"></siteMapNode>
<siteMapNode url="/chp04/webForm3.aspx" title="站点地图"></siteMapNode>
<siteMapNode url="/chp04/ZzhDemo.aspx" title="呵呵"></siteMapNode>
</siteMapNode>
</siteMapNode>
</siteMap>
TreeView数据来源 表设计

parentNodeid与nodeid对应 parentnodeid 0 的话就是根目录, 代码如下
public partial class BingTreeView : System.Web.UI.Page
{
//也可以使用list泛型集合
DataTable dt = new DataTable();
protected void Page_Load(object sender, EventArgs e)
{
// foreach(DataRow row in dt.Rows)
// {
// SysFun fun = new SysFun()
// {
// NodeId = Convert.ToInt32(row["nodeId"]),
// DisplayName = row["DisplayName"].ToString(),
// DisplayOrder = Convert.ToInt32(row["DisplayOrder"]),
// ParentNodeId = Convert.ToInt32(row["ParentNodeId"]),
// NodeUrl = row["nodeUrl"].ToString()
// };
// list.Add(fun);
// }
string sql = "select * from [SysFun]";
dt = SQLHelper.ExcuteTable(sql,null).Tables[0];
BindTree("0",TreeView1.Nodes); //参数:(从头开始 根节点)
}
public void BindTree(string parentId,TreeNodeCollection tnc)
{
DataView dv = dt.DefaultView; //返回可用于筛选的集合
dv.RowFilter = "parentNodeId="+parentId; //筛选出符合treeview规则的dv
foreach (DataRowView row in dv)
{
TreeNode newtn = new TreeNode(); //声明treenode
newtn.Text = row["Displayname"].ToString();
newtn.NavigateUrl = row["NodeUrl"].ToString();
newtn.Value = row["NodeId"].ToString();
tnc.Add(newtn);
BindTree(newtn.Value,newtn.ChildNodes);//继续回调 找完继续找parentNodeId(方法结束继续Foreach)
}
}
}
分析:回调的方法是为了添加一个根目录的所有子集 添加完一个根节点的所有子集 foreach就会结束,那么方法执行就会结束,再次回到非回调的方法中 继续加载,直到所有根节点的子集全部加载完 ,此时bindtree方法就会结束。
母版页 treeview控件 SiteMapPath控件 treeview数据库绑定模式的更多相关文章
- MVC树控件,mvc中应用treeview,实现复选框树的多层级表单控件
类似于多层级的角色与权限控制功能,用MVC实现MVC树控件,mvc中应用treeview,实现复选框树的多层级表单控件.最近我们的项目中需要用到树型菜单,以前使用WebForm时,树型菜单有微软提供的 ...
- asp.net 第三方UI控件 Telerik KendoUI 之 TreeVIew 的用法记录
一.前台显示 备注:一次性取出所有节点 function loadTreeData() { $.ajax({ type: 'POST', url: '@(Html.UrlHref("Scri ...
- “眉毛导航”——SiteMapPath控件的使用(ASP.NET)
今天做网站的时候,用到了SiteMapPath控件,我把使用方法记录下来,以便日后查阅以及帮助新手朋友们. SiteMapPath”会显示一个导航路径(也称为痕迹导航或眉毛导航),此路径为用户显示当前 ...
- “面包屑导航”——SiteMapPath控件的使用(ASP.NET)(转)
转自:http://www.cnblogs.com/ball-head/archive/2010/09/28/1837253.html 最近在博客里写了一些日志,主要都是我在实际编程过程中遇到的问题. ...
- SiteMapPath控件的使用(ASP.NET)
最近在博客里写了一些日志,主要都是我在实际编程过程中遇到的问题.问题出现后,先自己推敲,搞不定的,就上网去搜,再就是请教同学.同事,从中获益匪浅,也很难得!现在把感觉比较实用的一些功能代码之类的发布到 ...
- 【原创】自己动手写控件----XSmartNote控件
一.前面的话 在上一篇博文自己动手写工具----XSmartNote [Beta 3.0]中,用到了若干个自定义控件,其中包含用于显示Note内容的简单的Label扩展控件,用于展示标签内容的labe ...
- winform用户控件、动态创建添加控件、timer控件、控件联动
用户控件: 相当于自定义的一个panel 里面可以放各种其他控件,并可以在后台一下调用整个此自定义控件. 使用方法:在项目上右键.添加.用户控件,之后用户控件的编辑与普通容器控件类似.如果要在后台往窗 ...
- paip.gui控件tabs控件加载内容的原理以及easyui最佳实现
paip.gui控件tabs控件加载内容的原理以及easyui最佳实现 //////////////tabs控件的加载 同form窗体一样,俩个方式 两个方式:一个是url,简单的文本可以使用这个,不 ...
- iOS开发中的错误整理,关于用绑定Tag取控件的注意事项,有时候不绑定也是个错!
如图:红色框中是个自定义的导航工具条titlesView(没有绑定Tag),工具条中有五个按钮(按钮绑定了Tag)以及一个红色的指示器indicatorView(没有绑定Tag),下面的蓝色是可以滚动 ...
随机推荐
- vscode代码自动补全失效
前段时间,朋友说自己的vscode突然出现了代码不能自动补全的问题(主要是js,其他语言也可以参考) 症状表现为,刚打开vscode有自动补全,过了一会,突然就没了,反反复复 解决过程也是相当坎坷了 ...
- Linux搭建NFS服务
一.NFS服务简单介绍 NFS(Network File System)即网络文件系统,是FreeBSD支持的文件系统中的一种,它允许网络中的计算机之间通过TCP/IP网络共享资源.在NFS的应用中, ...
- NodeJS1-2 Node JS的优点
NodeJS并不适合所有server端的场景,它的使用场景是及其有限的,web是nodeJS最适合的场景 前端偏爱node的原因其内核就是JavaScript 前端职责范围变大,统一开发体验 在处理了 ...
- 在MySQL中group by 是什么意思
mysql语法中group by是什么意思? 在百度中搜索半天,最后找到一篇解释比较好的(不是博文,是百度知道,很郁闷那么多网友怎么就没人解释的清楚),链接如下: http://zhidao.baid ...
- 面试连环炮系列(二十三): StringBuffer与StringBuild的区别
StringBuffer与StringBuild的区别 频繁修改字符串时,建议使用StringBuffer和StringBuilder类.StringBuilder相较于StringBuffer有速度 ...
- CROSS-ENV不同环境配置
项目背景 为了适应h5环境搭建需求,需要动态配置开发,测试,生产三种对应域名及其及打包命令.使用cross-env可以让配置环境更加清晰明了还好管理. 简介 cross-env的作用是不需要全局配置N ...
- phper使用MySQL 针对千万级的大表要怎么优化?
有需要学习交流的友人请加入交流群的咱们一起,群内都是1-7年的开发者,希望可以一起交流,探讨PHP,swoole这块的技术 或者有其他问题 也可以问,获取swoole或者php进阶相关资料私聊管理即可 ...
- SpringMVC 自定义参数解析器.
一.简述 有没有想过像 @RequestParam.@RequestBody 这些注解的工作原理呢?为什么 form 表单.application/json 的参数能够直接封装进 Bean 对象中呢? ...
- Nacos 集群部署
关于nacos 集群部署,网上的示例往往不全或不可用,而官方的教程太简单了.官方也提供了一个 docker + nacos 的伪集群的 部署示例.但毕竟是 伪, 不能实际生产使用. 全网就几乎就没有 ...
- 每个Web开发者都该了解的12条命令行
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者.原文出处:https://tutorialzine.com/2017/08/12-terminal-comma ...