前台ext treestore id重复的解决方法。

前几天遇到这个问题,是人员的管理,一个组织下面有其他子组织,一个人可以属于多个组织。这样的情况出现了同个tree 中store id出现重复的现象。

这时候需要对他的id进行拼接。

我查了api,找到store 有个事件,是load,在他load的时候对他进行拼接原理就是:“如果一个节点不属于跟节点,他的id就是父节点id+本身id”。

  listeners:{  
        beforeload:function(){  
             // Ext.MessageBox.alert('提示',"数据开始加载") 
        },
        load:function(store,records,successFull,o){
        		Ext.each(records,function(item){
        			var childs=item.childNodes;
        			//alert(item.data.id);
        			Ext.each(childs,function(child){
        				if('root'!=item.data.id){
        					child.setId(item.data.id+'-'+child.data.id);
        					child.commit();
        				}
        			});
        			//item.commit();
        		});
        }

    }


写一个工具类(用来解析节点id):

Ext.define("app.system.util.strSplitUtil",{
	/**
	 * 分割字符串,获得需要的id
	 * @param {} 
	 * @param {} 
	 */
	getTreeNodeId:function(nodeId){
		var id='';
		if((typeof nodeId=='string')&&nodeId.constructor==String){//有时候我们id并没有-,系统会认为不是string类型
			var ids=nodeId.split("-");
			if('root'==nodeId){
				id=nodeId;
			}
			else{
		        id=ids.pop();
			}
		}	
        else{
			id=nodeId;
		}		

		return id;
	},
	getTreeNodeIds:function(nodeId){//操作数组的方法
		 var ids=[];
		 var id='';
		 var count=0;
         if((typeof nodeId=='object')&&nodeId.constructor==Array){       	
			for(i=0;i<nodeId.length;i++){
				count=count+1;
				if((typeof nodeId[i]=='number')&&nodeId[i].constructor==Number){
					nodeId[i]=String(nodeId[i]);
				}
				var tempIds=nodeId[i].split("-");
			    ids.push(tempIds.pop());
			}
			 
		}
		return ids;
	},
	getParenIds:function(nodeId){//通过输入一个id,获得它和它所有的父节点id
		var ids=[];
		if((typeof nodeId=='string')&&nodeId.constructor==String){//有时候我们id并没有-,系统会认为不是string类型
			var ids=nodeId.split("-");
		}	
        else{
			ids[0]=ids.push(nodeId.toString());
		}		
		return ids;
	}
	/*,
	test:function(){
	     alert('test');
	}*/
});

在controller中混入工具类:

 mixins: {
  strSplitUtil:"app.system.util.strSplitUtil"
 },
可拿到id了:

var self=this

var id=self.getTreeNodeId(record.get("id"));

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值