dtree+右键菜单 完美结合,超级简单的实现方法
dtree 这个 树控件,在WEB 开发中,使用的比较多,而且用起来比较方便,效果显示的也不错。但是在实际的开发中,往往不只是显示而已,要对树进行,增删改 操作。如果能有个右键菜单,那就好了,可是,dtree 并没有提供这个功能。
为了实现 dtree + 右键菜单的效果,我也是查阅了一些资料,有的实现起来比较麻烦,我就写了一个相对简单的方法,来实现这种效果。说了这么多,先看下效果吧。
dtree + 右键菜单 (完美结合)
图形界面,我没有去修饰,CSS 大家可以自定义来实现更好的效果。
如果这个dtree+右键菜单s效果,就是你要的效果,那请你继续往下看吧。
实现原理:
通过修改页面的右键菜单,来实现。
实现步骤:
1. 先引入dtree 需要的js , css ,图片 等资源;
2. 在页面生成一个 dtree 树;
3.在页面上 自定义 一个右键菜单;
4. 在dtree 的 url属性中:写入[ javascript:函数名(参数名);]此处为,单击树要执行的JS;
5. 此处调用的JS函数,主要 功能就是更改页面的右键菜单,让用户在选中的节点上,右键点击时,出现自定义的右键菜单;
6. 再写一个 函数,来实现: 用户单击页面除了自定义右键菜单以外的地方,右键菜单消失,并且还原页面本来的右键菜单;(此处根据需要进行取舍)
好了,原理和步骤就是这样,现在请看代码: (代码为 asp.net 示例,如果是web开发其他语言,也可通过这种原理来轻松实现)
<!-- 先引入dtree 需要的js , css ,图片 等资源;-->
<%--生成树样式--%>
<link rel="Stylesheet" type="text/css" href="dtree.css" />
<%--生成树文件--%>
<script type="text/javascript" src="dtree.js" ></script>s
<script language="javascript" type="text/javascript">
<!-- 在页面生成一个 dtree 树; -->
tree = new dTree('tree');
tree.config.useStatusText=true;
tree.config.closeSameLevel=true;
tree.config.useCookies = false;
tree.add(0, -1, "Tree example", "javascript: loadMenu('abc');");
tree.add(1, 0, "Node 1", "javascript:loadMenu();");
tree.add(2, 1, "Node 2", "javascript:loadMenu();");
tree.add(3, 1, "Node 3", "javascript:loadMenu();");
tree.add(4, 0, "Node 4", "javascript:loadMenu();");
tree.add(5, 4, "Node 5", "javascript:loadMenu();");
tree.add(6, 4, "Node 6", "javascript:loadMenu();");
tree.add(7, 2, "Node 7", "javascript:loadMenu();");
tree.add(8, 6, "Node 8", "javascript:loadMenu();");
tree.add(9, 1, "Node 9", "javascript:loadMenu();");
tree.add(10, 2, "Node 10", "javascript:loadMenu();");
document.write(tree);
<!-- 节点点击调用的JS函数,主要 功能就是更改页面的右键菜单,让用户在选中的节点上,右键点击时,出现自定义的右键菜单;-->
//点击节点后,将右键菜单更改为自定义的菜单
function loadMenu(obj) {
//获取参数
var param = obj;
// ... 通过获取 参数 来,执行方法
//............................
//............................
//重写 -- 页面点击右键菜单事件
document.oncontextmenu = function() {
//定位,显示
contextmenu.style.posLeft = document.body.scrollLeft + event.x + 10;
contextmenu.style.posTop = document.body.scrollTop + event.y + 10;
contextmenu.style.display = "inline";
return false;
}
}
<!-- 用户单击页面除了自定义右键菜单以外的地方,右键菜单消失,并且还原页面本来的右键菜单的JS函数s-->
//单击页面上除了菜单以外的地方,隐藏右键菜单
document.onclick = function() {
//判断单击的是否为右键菜单
//如果不是,隐藏右键菜单
if (document.activeElement != contextmenu) {
contextmenu.style.display = "none"
//还原页面本来的右键菜单
document.oncontextmenu = '';
}
}
//颜色变量
var colorTemp = "";
</script>
<!-- 页面布局中的自定义右键菜单 -->
<!-- 右键菜单开始 -->
<div id="contextmenu" align="center" style="border:1px solid #666666;background:#eeeeee; width:100px;padding:0px;display:none;position:absolute">
<table style=" width:100px; font-size:12px; border:dashed 1px black; ">
<tr>
<td id="modAttribute" onclick="javascript:alert('编辑');" onmouseover="javascript:colorTemp=this.style.backgroundColor;this.style.backgroundColor='#98B4CE';" onmouseout="javascript:this.style.backgroundColor=colorTemp;" style=" background-color:#F5F5D1; height:15px; border-bottom:1px solid black; " > <!-- 编辑事件 -->
编辑
</td>
</tr>
<tr>
<td id="modEvent" onclick="javascript:alert('删除');" onmouseover="javascript:colorTemp=this.style.backgroundColor;this.style.backgroundColor='#98B4CE';" onmouseout="javascript:this.style.backgroundColor=colorTemp;" style=" background-color:#F5F5D1; height:15px; border-top:1px solid black; " > <!-- 删除事件 -->
删除
</td>
</tr>
</table>
</div>
<!-- 右键菜单结束 -->
好了,效果就实现了,是不是很简单啊?嘿嘿
如果是其他语言的WEB 开发,也可以通过这种原理来实现。
好了,就说到这了,大家多多交流,如果有更好的建议,欢迎您提出。