Extjs4.2 TreeView TreeStore 移除节点不触发delete(remove node don't trigger delete method)
2013-12-19 18:04
741 查看
当我们操作treeview的时候,新增节点,如果成功则新增node,如果失败的话我们不想node还显示出来,可以通过监听sync的failure事件,失败时候移除node,但是第一次肯定达到了预期效果,这时候如果我们再新增一个node,也是失败的情况,就会触发两个事件,一个是本次的node add,另一个是上次的node delete。
http://docs.sencha.com/extjs/4.2.2/#!/api/Ext.data.NodeInterface-method-remove
API介绍,移除树节点的时候可以通过node.remove(true),来禁止触发delete方法,但是每次都提示错误:Cannot call method 'indexOf' of undefined
无奈,根据原理,删除后的节点其实是存放在removed数组里面的,我们只需要将这个数组清空即可。
http://docs.sencha.com/extjs/4.2.2/#!/api/Ext.data.NodeInterface-method-remove
API介绍,移除树节点的时候可以通过node.remove(true),来禁止触发delete方法,但是每次都提示错误:Cannot call method 'indexOf' of undefined
无奈,根据原理,删除后的节点其实是存放在removed数组里面的,我们只需要将这个数组清空即可。
var mg = this.getModuleGrid() var selModel = mg.getSelectionModel(); records = selModel.getSelection(); module["ModuleParent"] = records[0].data.id; _node = records[0].appendChild(module); mstore.sync({ success: function (batch, options) { if (records[0].get("leaf")) { records[0].set("leaf", false); } records[0].expand(); }, failure: function (batch, options) { records[0].removeChild(_node);//removeChild(_node,true)异常 mstore.removed = []; } });
相关文章推荐
- Winform 点击TreeView控件节点的CheckBox不触发NodeMouseClick事件的做法
- EXTJS 4.2 资料 控件之Grid 行编辑绑定下拉框,并点一次触发一次事件
- ExtJs 4.2 treePanel 点击树节点 传送参数到后台(多个参数)
- 操作TreeView:,选中左边树的节点,点击>>按钮 将选择的节点展现到右边的树中,同时将选择的节点从左边的树中移除。。点击<<实现同样的功能。。。。
- Extjs4.2 TreePanel+Asp.net mvc 动态加载节点
- ExtJS 4.2 treeStore设置autoLoad但是还是会自动加载的问题
- ExtJS 4.2 树形结构请求后台数据无法展示子节点,而是没点击一次请求一次数据,无限请求加载所有的父节点元素
- 关于如何移除TreeView中的所有选中节点的一点体会
- extjs4.2 隐藏treePanel 的节点
- TreeView 点击触发父节点、子节点的连锁反应选中与取消
- TreeView控件中选中节点前的checkBox仍然会触发NodeMouseClick事件
- C#WINDOW VS2015 c#TreeView 之后点击树中的任何一个节点,触发事件问题
- 在TreeView节点上点击右键触发选中该节点的方法
- TreeView1鼠标点击节点触发的单击事件
- TreeView节点 (前台JS 设置 Postback 触发TreeNodeCheckChanged 事件)
- 如何移除TreeView中的所有选中节点
- Extjs 4.2 右键菜单树节点(,选择逆,废除)
- extJS 4.2 自定义分页
- asp.net 获取TreeView中第一个选中的节点
- 设置无刷新TreeView选中节点样式