作者:王力猛(网名:wallimn、邮件:wallimn@sohu.com)
博客:http://blog.csdn.net/wallimn
时间:2007-08-31
声明:此文欢迎转载,转载请保留本人信息。如果对您有帮助,希望心存感激,呵呵。更多文章,请访问我的博客。

  做WEB程序的人多数应该听说过dtree,这个插件还不错,简单、效率还算可以,而且可以在cookie中保存树的状态(刷新页面树会保持节点展开、收拢状态),如果节点量不是很大的情况下,是个不错的选择。我在好几个项目里都用到过。但这个插件不带checkbox,这不能不说是个遗憾,因为这个应用场合还是很多的。
  现在对javascript程序有了较多的了解,决定自己给dtree添上这个功能,写这两句话的意思是告诉大家,在已有插件的基础上DIV并不是很困难,呵呵。just do it。
  dtree的节点(Node)是个对象,所有节点保存在树(dTree)对象的一个属性里,重载了两个对象的toString()函数,在页面显示的时候执行所有的toString()操作。搞清程序的大致流程,改造工作就比较简单了,分以下几步:
  1.给树对象的config对象添加一个控制checkbox是否显示的属性;
   this.config = {
    target     : null,
    folderLinks   : true,
    useSelection  : true,
    useCookies   : true,
    useLines    : true,
    useIcons    : true,
    useStatusText  : false,
    closeSameLevel : false,
    inOrder     : false,
    check:false  //**新加的
  } 

  2.修改节点对象的toString()方法,添加...input type="checkbox"...代码;
  if(this.config.check==true){
   str+= '<input type="checkbox" id="c'+  this.obj + nodeId + '" onclick="javascript:'+this.obj+'.cc('+nodeId+')"/>';
  }
  
  3.写checkbox页面元素的onclick事件处理函数,这个函数用来智能控件树节点的checkbox状态。也就是说,勾选一个节点的checkbox,自动勾选其所有父节点及其所有子节点;取消勾选节点的checkbox,自动取消勾选其所有子节点的勾选状态,而其父节点的勾选状态不变。这个是个比较重要的新功能,一些具有checkbox的页面插件并不具备这个功能,这个功能使用递归算法实现。
  dTree.prototype.cc=function(nodeId){
  var cs = document.getElementById("c"+this.obj+nodeId).checked;
  var n,node = this.aNodes[nodeId];
  var len =this.aNodes.length;
  for (n=0; n<len; n++) {
   if (this.aNodes[n].pid == node.id) {
    document.getElementById("c"+this.obj+n).checked=cs;
    this.cc(n);  
   }
  }
  if(cs==false)return;
  var pid=node.pid;
  var bSearch;
  do{
   bSearch=false;
   for(n=0;n<len;n++){
    if(this.aNodes[n].id==pid){
     document.getElementById("c"+this.obj+n).checked=true;
     pid=this.aNodes[n].pid;
     bSearch= true;    
     break;
    }
   }
  }while(bSearch==true);
 }

  基本这样这可以了。如果嫌以上叙述不清楚,或者想省事不想自己修改,可以跟我联系索取所有源码。
  我还使用jsp对这个树形控件进行了封装,这个封装使用很简单。利用jsp:include标签包含我封装的jsp文件,传入参数(jsp:param):从数据库中取记录的SQL语句,可自动在页面上根据数据库记录生成树形控件。如果你的系统中大量用到树形控件,这会对你有很大的帮助。

posted on 2008-03-05 13:35  snwsky  阅读(2902)  评论(4编辑  收藏  举报