ztree-demo 2
- <!DOCTYPE html>
- <HTML>
- <HEAD>
- <TITLE> ZTREE DEMO - Async</TITLE>
- <meta http-equiv="content-type" content="text/html; charset=UTF-8">
- <link rel="stylesheet" href="css/demo.css" type="text/css">
- <link rel="stylesheet" href="css/zTreeStyle/zTreeStyle.css" type="text/css">
- <script type="text/javascript" src="js/jquery-3.1.0.min.js"></script>
- <script type="text/javascript" src="js/jquery.ztree.core.js"></script>
- <script type="text/javascript" src="js/jquery.ztree.excheck.js"></script>
- <script type="text/javascript" src="js/jquery.ztree.exedit.js"></script>
- </HEAD>
- <BODY>
- <ul id="treeDemo" class="ztree"></ul>
- <button type="button" class="save">保存</button>
- <table>
- <tr data_id="1">
- <td class="title"><a href="javascript:void(0)" class="update">修改</a><a href="javascript:void(0)" class="delete">删除</a></td>
- <td class="filePath">n1/n1.n1/n1.n1.n1/n1.n1.n1.n3<br>n3/n3.n2</td>
- </tr>
- <tr data_id="2">
- <td><a href="javascript:void(0)" class="update">修改</a><a href="javascript:void(0)" class="delete">删除</a></td>
- <td class="filePath">n1/n1.n1/n1.n1.n1/n1.n1.n1.n4<br>n3/n3.n3/n3.n3.n1/n3.n3.n1.n2</td>
- </tr>
- </table>
- <SCRIPT type="text/javascript">
- <!--
- var setting = {
- check: {
- enable: true
- },
- async: {
- enable: true,
- url:"demo/cn/asyncData/getNodes.php",
- autoParam:["id", "name=n", "level=lv"],
- otherParam:{"otherParam":"zTreeAsyncTest"},
- dataFilter: filter
- },
- callback: {
- onAsyncSuccess: onAsyncSuccess,
- onExpand: onExpand,
- onCheck: onCheck,
- onNodeCreated: onNodeCreated
- }
- };
- var zTreeObj;
- $(document).ready(function(){
- zTreeObj = $.fn.zTree.init($("#treeDemo"), setting);
- });
- function filter(treeId, parentNode, childNodes) {
- if (!childNodes)
- return null;
- childNodes.forEach(function(childNode){
- // 计算路径
- var path = '';
- if(!parentNode){
- path = childNode.name;
- }else{
- path = parentNode.filePath + '/' + childNode.name;
- }
- childNode.filePath = path;
- // 判断是否已选中
- var checked = false;
- var halfCheck = false;
- var chkDisabled = false;
- $(".filePath").each(function(i, item){
- var filePathArray = $(item).html().trim().split('<br>');
- filePathArray.forEach(function(filePath){
- filePath = filePath.trim();
- if(filePath == childNode.filePath){// 全匹配(叶节点)
- checked = true;
- if(jQuery.inArray(filePath,filterFilePathArray) < 0){
- chkDisabled = true;
- }
- }else if(filePath.indexOf(childNode.filePath) == 0){// 部分匹配(父节点)
- checked = true;
- // halfCheck = true;
- }
- });
- });
- childNode.checked = checked;
- childNode.halfCheck = halfCheck;
- childNode.chkDisabled = chkDisabled;
- });
- return childNodes;
- }
- function onAsyncSuccess(event, treeId, treeNode, msg) {
- console.log(treeNode);
- }
- function onExpand(event, treeId, treeNode) {
- // console.log(treeNode);
- };
- function onCheck(event, treeId, treeNode) {
- // console.log(treeNode);
- };
- function onNodeCreated(event, treeId, treeNode) {
- if(treeNode.checked){
- zTreeObj.expandNode(treeNode, true, false, false, false);
- }
- };
- //-->
- </SCRIPT>
- <SCRIPT type="text/javascript">
- <!--
- var filterFilePathArray = [];
- var nowUpdateIndex = -1;
- $(document).on("click", ".delete", function(){
- $(this).parents("tr").remove();
- zTreeObj.destroy();
- zTreeObj = $.fn.zTree.init($("#treeDemo"), setting);
- });
- $(document).on("click", ".update", function(){
- nowUpdateIndex = $(this).parents("tr").attr("data_id");
- filterFilePathArray = [];
- var filePathArray = $(this).parents("td").siblings(".filePath").text().html().split('<br>');
- filePathArray.forEach(function(filePath){
- filePath = filePath.trim();
- filterFilePathArray.push(filePath);
- });
- zTreeObj.destroy();
- zTreeObj = $.fn.zTree.init($("#treeDemo"), setting);
- });
- $(document).on("click", ".save", function(){
- var str = '';
- var nodes = zTreeObj.getCheckedNodes();
- if(!!nodes){
- var i = 0;
- nodes.forEach(function(node){
- if(!node.isParent){
- if(i == 0){
- str = node.filePath;
- }else{
- str = str + '<br>' + node.filePath;
- }
- i++;
- }
- });
- }
- if(str==''){
- return;
- }
- if(nowUpdateIndex<=0){
- var id = $("tr").length + 1;
- id = id + '.' + Math.floor(Math.random()*100+1);
- $("table").append("<tr data_id='"+id+"'><td><a href='javascript:void(0)' class='update'>修改</a><a href='javascript:void(0)' class='delete'>删除</a></td><td class='filePath'>"+str+"</td></tr>");
- }else{
- $("<tr data_id='"+nowUpdateIndex+"'><td><a href='javascript:void(0)' class='update'>修改</a><a href='javascript:void(0)'' class='delete'>删除</a></td><td class='filePath'>"+str+"</td></tr>").replaceAll("tr[data_id='"+nowUpdateIndex+"']");
- }
- zTreeObj.destroy();
- zTreeObj = $.fn.zTree.init($("#treeDemo"), setting);
- });
- //-->
- </SCRIPT>
- </BODY>
- </HTML>
ztree-demo 2的更多相关文章
- jQurey zTree Demo 3.5
https://jeesite.gitee.io/front/jquery-ztree/3.5/demo/cn/index.html
- ztree : 增删改功能demo与自定义DOM功能demo的结合
最近有个项目要用ztree,需要用ztree自带的功能(增删改),也需要自定义DOM的功能(置顶). ztree的demo里有增删改的demo,也有自定义DOM的demo,但没有两者结合的. 所以我把 ...
- js树形控件—zTree使用总结
0 zTree简介 树形控件的使用是应用开发过程中必不可少的.zTree 是一个依靠 jQuery 实现的多功能 “树插件”.优异的性能.灵活的配置.多种功能的组合是 zTree 最大优点. 0.0 ...
- zTree学习
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 简单Ztree的实现————不连接数据库版
Ztree可以去官网去下载相应的版本和API,我这里就简单的介绍下它的实现以及因为Ztree的小例子印发的Js问题,稍后我会在博客中写JS的异步问题, 我这里用的是MVC4.0,好了正文开始,上代码 ...
- 【zTree】 zTree使用的 小例子
使用zTree树不是第一次了 但是 还是翻阅着之前做的 对照着 使用起来比较方便 这里就把小例子列出来 总结一下使用步骤 这样方便下次使用起来方便一点 使用zTree树的步骤: 1.首先 在 ...
- (菜鸟要飞系列)四,基于Asp.Net MVC5的后台管理系统(zTree绑定Json数据生成树)
上一次老师让我们用递归将中国城市镇县四级联动 显示在树上,那个时候就知道可以显示在zTree上,可是苦于对Json的不了解,对zTree的Api的不了解,一直没有做出来,只好将递归算法显示在了窗体上, ...
- jquery——zTree, 完美好用的树插件
Demo 这绝对是我见过最完美的tree了,尽管是国产货,但一点不输国外产品,国外的还没有见过这么强的. _______________________________________________ ...
- 使用zTree和json构建简单树节点
我们经常碰到须要构建树结构展示的情况,我推荐使用zTree和JSON. 比如: <? php /** * * 使用zTree和json构建树节点 * */ $arr = array( 0=> ...
- 【Ztree】前台展示多级菜单,后台配置方法
第一步.前台HTML页面. <%@ Page Language="C#" AutoEventWireup="true" CodeBehind=" ...
随机推荐
- 关于javascript的运动教程
一.javascript的匀速运动 关于物体的javascript匀速运动要点分析: 1.物体关于运动的时候,我们要打开定时器 2.打开定时器的时候我们记得要在停止的时候关闭定时器,同时应该注意的是一 ...
- 安装cocoapods
1. 看一下ruby的版本 ruby -v 2. 删除默认源 gem sources --remove https://rubygems.org/ 3. 添加淘宝源 gem sources -a ht ...
- HTML 字符实体 < >: &等
在 HTML 中,某些字符是预留的. 在 HTML 中不能使用小于号(<)和大于号(>),这是因为浏览器会误认为它们是标签. 如果希望正确地显示预留字符,我们必须在 HTML 源代码中使用 ...
- BZOJ 1711: [Usaco2007 Open]Dining吃饭
1711: [Usaco2007 Open]Dining吃饭 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 902 Solved: 476[Submit ...
- Jackson 通过自定义注解来控制json key的格式
Jackson 通过自定义注解来控制json key的格式 最近我这边有一个需求就是需要把Bean中的某一些特殊字段的值进行替换.而这个替换过程是需要依赖一个第三方的dubbo服务的.为了使得这个转换 ...
- Shell入门
前言 日常用Python多一些,不过很多时候shell脚本更简单实用一些,所以有必要熟悉一下shell脚本.当然shell有他特定的一些场景,比方说我曾经改过一个vpn断线自动重连的脚本,简单实用. ...
- sql server中对xml进行操作
一.前言 SQL Server 2005 引入了一种称为 XML 的本机数据类型.用户可以创建这样的表,它在关系列之外还有一个或多个 XML 类型的列:此外,还允许带有变量和参数.为了更好地支持 XM ...
- webapi-crud
- 使用ab对nginx进行压力测试
nginx以高并发,省内存著称. 相信大多数安装nginx的同学都想知道自己的nginx性能如何. 我想跟大家分享下我使用ab工具的压力测试方法和结果, ab是针对apache的性能测试工具,可以只安 ...
- MTK MT33xx型GPS的NMEA协议解析实例
1)解析实现 gps_main.c #include <nmea/nmea.h> #include <string.h> #include <stdio.h> #i ...