Ext 中的Tree实现不同节点不同的右键菜单

本文介绍如何在ExtJS框架中使用Tree组件的自定义属性type,并通过Tree.TreeLoader加载数据后,根据type属性的不同值在上下文菜单中展示不同选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

首先了解 Ext.Tree.Node.attributes的用法:

定义如下数据(其中有自定义类型type):

js 代码
  1. [{"text":"a","id":"1","cls":"folder","type":"4"},{"text":"b","id":"2","cls":"folder","type":"3"}]  

通过 Tree.TreeLoader 加载数据后可以通过如下语法读取type自定义属性

js 代码
  1. node.attributes.type  

 

了解自定义属性用法后可在Tree的contextmenu事件中控制不同类型的结点显示不同的菜单了,关键代码:

js 代码
  1. prepareCtx:function(node, e){   
  2.         node.select();   
  3.         if(node.attributes.type=="3");{   
  4.        ctxMenu.showAt(e.getXY());   
  5.         }   
  6.        if(node.attributes.type=="4"){   
  7.          ctxMenu1.showAt(e.getXY());   
  8.        }   
  9.       }   

 

完整例子见附件,注:此例子中包含ext库文件,如需运行需将ext库文件放入ajax/yui目录

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值