zTree实现节点修改的实时刷新
一、应用场景
二、项目实践
三、代码实现
1、初始化时必须设置配置
- <span style="font-size:14px;"> async:{
- enable:true,
- url:"../admin/scriptManager/loadNodeByID.htm",
- autoParam:["id"],
- dataType:"json",
- },
- view: {
- selectedMulti: false
- }
- }</span>
2、刷新方法
- 2、刷新方法
- /**
- * 刷新当前节点
- */
- function refreshNode() {
- /*根据 treeId 获取 zTree 对象*/
- var zTree = $.fn.zTree.getZTreeObj("scriptTree"),
- type = "refresh",
- silent = false,
- /*获取 zTree 当前被选中的节点数据集合*/
- nodes = zTree.getSelectedNodes();
- /*强行异步加载父节点的子节点。[setting.async.enable = true 时有效]*/
- zTree.reAsyncChildNodes(nodes[0], type, silent);
- }
- /**
- * 刷新当前选择节点的父节点
- */
- function refreshParentNode() {
- var zTree = $.fn.zTree.getZTreeObj("scriptTree"),
- type = "refresh",
- silent = false,
- nodes = zTree.getSelectedNodes();
- /*根据 zTree 的唯一标识 tId 快速获取节点 JSON 数据对象*/
- var parentNode = zTree.getNodeByTId(nodes[0].parentTId);
- /*选中指定节点*/
- zTree.selectNode(parentNode);
- zTree.reAsyncChildNodes(parentNode, type, silent);
- }
3、涉及的方法详解
1、$.fn.zTree.init(obj,zSetting,zNodes)zTree的初始化方法,创建zTree必须使用此方法
参数说明
obj JQuery Object用于展现zTree的DOM容器
zSetting JSON zTree的配置数据,具体请参考 “setting 配置详解”中的各个属性详细说明
zNodes Array(JSON)/JSON zTree的节点数据,具体请参考 “treeNode 节点数据详解”中的各个属性详细说明
返回值
zTree对象,提供操作zTree的各种方法,对于通过js操作zTree来说必须通过此对象
如果不需要自行设定全局变量保存,可以利用
2、zTreeObj.getSelectedNodes获取 zTree 当前被选中的节点数据集合
返回值
返回值 Array(JSON)当前被选中的节点数据集合
方法实例:
1. 获取当前被选中的节点数据集合
var treeObj = $.fn.zTree.getZTreeObj("tree");
var nodes = treeObj.getSelectedNodes();
3、zTreeObj.getNodeByTId根据 zTree 的唯一标识 tId 快速获取节点 JSON 数据对象
参数:tId String 节点在 zTree 内的唯一标识 tId
返回值:返回值 JSON tId 对应的节点 JSON 数据对象如无结果,返回 null
方法实例:
1. 获取 tId = "tree_10" 的节点数据
var treeObj = $.fn.zTree.getZTreeObj("tree");
var node = treeObj.getNodeByTId("tree_10");
4、zTreeObj.selectNode选中指定节点
参数:treeNode JSON 需要被选中的节点数据
addFlag Boolean
addFlag = true 表示追加选中,会出现多点同时被选中的情况
addFlag = false 表示单独选中,原先被选中的节点会被取消选中状态
setting.view.selectedMulti = false 时,此参数无效,始终进行单独选中
5、zTreeObj.reAsyncChildNodes强行异步加载父节点的子节点。[setting.async.enable = true 时有效]
参数:parentNode JSON 指定需要异步加载的父节点 JSON 数据,
reloadType String reloadType = "refresh" 表示清空后重新加载。reloadType != "refresh" 时,表示追加子节点处理
isSilent Boolean 设定异步加载后是否自动展开父节点。isSilent = true 时,不展开父节点,其他值或缺省状态都自动展开。
方法实例
1. 重新异步加载当前选中的第一个节点
var treeObj = $.fn.zTree.getZTreeObj("tree");
var nodes = treeObj.getSelectedNodes();
if (nodes.length>0) {
treeObj.reAsyncChildNodes(nodes[0], "refresh");
}
4、部分后台代码
- /**
- * 查询工程对象
- *
- * @return
- */
- @ResponseBody
- @RequestMapping("/loadNodeByID.htm")
- public List<ZTreeNode> loadNodeByID(Integer id) {
- List<ZTreeNode> nodes = cuScriptProjectService.loadNodesByID(id);
- // ZTreeNode zTreeNode = cuScriptProjectService.loadNodeByID(id);
- return nodes;
- }
- /**
- * 根据工程ID加载工程节点数据
- */
- @Override
- public List<ZTreeNode> loadNodesByID(Integer id) {
- /* 查询工程集合 */
- List<CUProject> allProjects = this.cuProjectDAO.findAllProjects();
- Map<Integer, List<CUProjectVO>> allPorjectList = this.buildProjectVOMap(allProjects);
- /* 查询脚本集合 */
- List<CUScript> allScripts = this.cuScriptDAO.findAllScripts();
- Map<Integer, List<CUScriptVO>> allScriptMap = this.buildScriptVOMap(allScripts);
- /* 构建ZTreeNode数据结构 */
- List<ZTreeNode> treeNodeList = new ArrayList<ZTreeNode>();
- loopBuildZTree(id, allPorjectList, allScriptMap, treeNodeList);
- return treeNodeList;
- }
zTree实现节点修改的实时刷新的更多相关文章
- grunt实现修改代码实时刷新浏览器
grunt例子:https://github.com/Aquarius1993/gruntDemo grunt 实时刷新1: 1.安装chrome浏览器插件:liveReload ...
- webpack实现修改代码实时刷新浏览器
webpack例子:https://github.com/Aquarius1993/webpackDemo 1. 需要全局和项目安装webpack和webpack-dev-server npm ins ...
- gulp使用 实现文件修改实时刷新
gulp例子:https://github.com/Aquarius1993/gulpDemo 淘宝镜像:$ npm install -g cnpm --registry=https://regist ...
- 使用SignalR实现比特币价格实时刷新
ASP.NET SignalR是微软支持的一个运行在 Dot NET 平台上的 HTML Websocket 框架.它出现的主要目的是实现服务器主动推送(Push)消息到客户端页面,这样客户端就不必重 ...
- Gulp-livereload:实时刷新编码
实现功能 监听指定目录下的所有文件,实时动态刷新页面 安装(Install) 功能的实现是借助 gulp-connect 插件完成的;所以,首先通过下面命令完成插件安装: npm install -- ...
- webpack-dev-server 搭建本地服务以及浏览器实时刷新
一.概述开发项目中为了保证上线,开发项目是都需要使用localhost进行开发,以前的做法就是本地搭建Apache或者Tomcat服务器.有的前端开发人员 对服务器的搭建和配置并不熟悉,这个时候需要后 ...
- JAVAFX之tableview界面实时刷新导致的内存溢出(自己挖的坑,爬着也要出来啊0.0)
这几天遇到了一个问题,不幸开发的一个cs架构的工具,客户端开启后,内存一直在缓慢增长最终导致进程卡死,花了4天时间,终于爬出来了... 客户端通过timer定时器每30秒查询一次数据库以及一些业务逻辑 ...
- webpack热加载:修改文件自动刷新浏览器并更新
概述 之前用react脚手架,觉得那种修改了能立即自动刷新浏览器并更新的功能实在非常人性化,所以想在开发其它项目的时候能用上.于是查了一些资料记录在此,供以后开发时参考,相信对其他人也有用. 其实代码 ...
- 转:zTree树控件扩展篇:巧用zTree控件实现文本框输入关键词自动模糊查找zTree树节点实现模糊匹配下拉选择效果
是否可以借助于zTree实现文本框输入关键词自动模糊匹配zTree下拉树,然后选择下拉树内节点显示在文本框内且隐藏下拉树. 看到这个需求脑子里头大致已经想到了要如何实现这样一个需求,当时是限于时间问题 ...
随机推荐
- Phpcms V9手机门户设置教程:怎么用PC V9做手机网站
一.在PHPcms V9管理后台设置手机门户 1.1.开启手机网站.位置:模块 >手机门户 > 添加手机站点,具体设置可参照截图: 填写站点名和LOGO文件相对位置,绑定用于手机网站的二级 ...
- docker dockerfile构建自己的tomcat镜像
文件 1.apache-tomcat-8.5.24.tar.gz, jdk-8u151-linux-x64.tar.gz Dockerfile文件: FROM centosWORKDIR /usrCO ...
- python 捕捉错误,exception,traceback和sys.exc_info()比较
import traceback,sys import requests try : requests.get('dsdsd') ##故意让他出错 except Exception,e: print ...
- Eclipse Maven 配置setting.xml 的镜像远程仓库
1.在.m2中新建settings.xml文件 1.window-->Preferences-->Maven-->User Settings 3.点击open file 编辑将远程仓 ...
- ios开发之--搜索框的使用(PYSearchViewController的使用)
最近需要开发搜索框,比较了以前的各个版本的搜索框,UISearchDisplayController和UISearchController的使用,以后再做记录,随着ios11的更新,一些控件发生了,改 ...
- Anaconda本地安装python库
很多时候我们需要自己手动安装一些库,例如因为网络原因,或者下载源没有这个包. 以Windows环境为例,无论是pip安装还是anaconda安装,最终的包都是安装在,工作目录/Lib/site-pac ...
- 【代码审计】iZhanCMS_v2.1 前台IndexController.php页面存在SQL注入 漏洞分析
0x00 环境准备 iZhanCMS官网:http://www.izhancms.com 网站源码版本:爱站CMS(zend6.0) V2.1 程序源码下载:http://www.izhancms ...
- linux系统开机自启程序-需要-root用户 -启动 -
#!/bin/bashsh /home/hwjc/RSA/release2017-02-23/release2017-02-23/install.shsh /etc/init.d/mqtt.shifc ...
- React Native(十一)——按钮重复点击事件的处理
最初开始做后台管理系统的时候,就曾遇到过这样一种场景:"快速点击确认按钮,就会对此触发确认事件,导致多次请求数据库":于是最终我们得当的通过处理那个确认button,解决了上述问题 ...
- Git学习(二)(2015年11月18日)(2016年1月29日)
2015年11月18日Git学习: .Shell 删除文件夹及其所有文件 rd/s/q 文件目录 ---------------当前为先创建本地Git库后与网上Git服务器关联------------ ...