一、在提前加载js的地方写一段js,判断该页面是否需要添加ztree,我的项目所有提前加载的js都写在admin.js中
//增加ztree
$(document).ready(function() {
var t = $('#tree-style').text();
if(t.length>0){
$('#col').addClass('sevice-table-container');
}
});
二、修改要显示ztree的html页面
{% extends 'layouts/admin_table_view.html' %}
//// 在admin_table_view.html中添加{% block tree %},在当前页面的{% block tree %}中加一个div,class要指明为ztree,他的样式来自于
zTreeStyle.css///
{% block tree %}
<div id="tree-style" class="ztree-style">
<ul id="Servicetree" class="ztree"></ul>
</div>
{% endblock %}
/////
{% block table_title %}
<h2>服务列表 <a type="button" href="{{url_for('admin.new_service_view')}}"class="btn btn-default btn-sm">
<span class="glyphicon glyphicon-plus" aria-hidden="true"></span> 新增服务
</a></h2>
{% endblock%} {% block table_header%}
<th>服务名称</th>
<th>服务管理员</th>
<th>服务等级</th>
<th>父级服务</th>
<th>上线时间</th>
<th>下线时间</th>
<th>操作</th>
{% endblock%} {% block table_scripts %}
<script>
var table_obj = {
"ajax":"{{url_for('api.get_services')}}",
"columns":[
{"data":"service_name"},
{"data":"manager"},
{"data":"service_level"},
{"data":"parent_service_id"},
{"data":null},
{"data":null},
{"data":null}
],
"columnDefs":[
{
"targets": -3,
"data": null,
"render": function ( data, type, full, meta ) {
var d = new Date(data.online_date)
return moment.utc(d).format('YYYY-MM-DD');
}
},
{
"targets": -2,
"data": null,
"render": function ( data, type, full, meta ) {
var d = data.offline_date
if (d == null)
{return ''}
else
{ d = new Date(d)
return moment.utc(d).format('YYYY-MM-DD');}
}
},
{
"targets": -1,
"data": null,
"render": function ( data, type, full, meta ) {
return '<a id="aburl" href="'+data.view_url+'" class="btn btn-sm btn-info item-detail" data-id='
+data.id
+'>修改</a> <button class="btn btn-sm btn-danger item-remove" data-id='
+data.id
+'>删除</button>';
}
}]
};
</script>
{% endblock%} ///在admin_table_view.html中添加{% block tree_scripts %},在当前页面的{% block tree_scripts %}中加一个js scripts,
另外,ztree使用的自带核心js是jquery.ztree.core.js,同时它依赖官方jquery>1.5版本,使用时先引入jquery
{% block tree_scripts %}
<script>
var zTreeObj;
// zTree 的参数配置,深入使用请参考 API 文档(setting 配置详解)
var setting = {
data: {
simpleData: {
enable: true,
idKey: "id", //节点id
pIdKey: "pId",//父id
rootPId: 0 //根id,一般为0即可
}
},
async: {
enable: true,
contentType: "application/json",
url: "{{url_for('api.generate_tree')}}", //获取数据的接口
autoParam: ["id", "name"], //根据id,name来获取数据
type:"get" //从接口获取数据的方式
}
}; $(document).ready(function(){
zTreeObj = $.fn.zTree.init($("#Servicetree"), setting);
});
</script>
{% endblock %} 三、叶子节点的图标样式zTreeStyle.css 父节点打开.ztree li span.button.ico_open{margin-right:2px; vertical-align:top; *vertical-align:middle;background:url(../images/img/open-folder-16.png) no-repeat scroll 0 0 transparent;}
父节点关闭.ztree li span.button.ico_close{margin-right:2px; vertical-align:top; *vertical-align:middle;background:url(../images/img/close-folder.png) no-repeat scroll 0 0 transparent;}
叶子节点.ztree li span.button.ico_docu{margin-right:2px; vertical-align:top; *vertical-align:middle;background:url(../images/img/layer_16px.png) no-repeat scroll 0 0 transparent;} 四、接口生成需要的数据,必须是json格式
@api.route('/services_tree/', methods=['GET'])
@token_authorize
def generate_tree():
#返回服务树的函数
services_tree = Services.query.all()
zNodes = [d.tree_to_json() for d in services_tree]
zNodes.append({"id": "-1", "pId": "0", "name": "服务", "open": "True"}) #添加根节点显示的内容,根节点id设为-1,根节点没有父id,顾令其父id为0
return jsonify(zNodes) 五、model获取每条相应数据
def tree_to_json(self):
"""返回服务树的相关数据"""
service_post = {
'id': self.id,
'pId': self.parent_service_id or '-1', #如果不存在父id,则令父id为-1
'name': self.service_name,
'url': url_for('admin.get_service_view', id=self.id, _external=True) #注意这里的字段名为ztree规定好的字段名
}
return service_post

ztree使用方法 python后台的更多相关文章

  1. DWZ 框架remote 验证字段唯一性方法提交后台,如果是中文会显示成乱码问题

    关于jquery  remote 验证字段唯一性方法提交后台,如果是中文会显示成乱码问题.可以直接修改tomcat 配置文件server.xml  设置 URIEncoding=utf-8属性,将ge ...

  2. jQuery AJAX 方法 success()后台传来的4种数据

    JAVA中的四种JSON解析方式详解 jQuery AJAX 方法 success()后台传来的4种数据 1.后台返回一个页面 js代码 /**(1)用$("#content-wrapper ...

  3. AJAX 与 Python 后台通信

    Ajax 简介 Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术. Ajax = 异步 ...

  4. python的str,unicode对象的encode和decode方法, Python中字符编码的总结和对比bytes和str

    python_2.x_unicode_to_str.py a = u"中文字符"; a.encode("GBK"); #打印: '\xd6\xd0\xce\xc ...

  5. Python后台开发Django(数据库)

    如果使用pymysql,则可以在view中直接import pymysql进行操作,与原操作无区别 Django数据库框架支持 sqlite3, MySQL, PostgreSQL等数据库,只需要在s ...

  6. Python后台开发Django(启动)

    Django版本为:2.1.7 Python的web框架,MTV思想 MVC Model(模板文件,数据库操作)  view(视图模板文件  )controller(业务处理) MTV Model(模 ...

  7. 转 zabbix 优化方法 以及 后台数据库查询方法 两则

    ############sample 1 https://blog.51cto.com/sfzhang88/1558254 如何从Zabbix数据库中获取监控数据 sfzhang关注6人评论40627 ...

  8. 矩阵或多维数组两种常用实现方法 - python

    在python中,实现多维数组或矩阵,有两种常用方法: 内置列表方法和numpy 科学计算包方法. 下面以创建10*10矩阵或多维数组为例,并初始化为0,程序如下: # Method 1: list ...

  9. 实现LRU的两种方法---python实现

    这也是豆瓣2016年的一道笔试题... 参考:http://www.3lian.com/edu/2015/06-25/224322.html LRU(least recently used)就不做过多 ...

随机推荐

  1. leetcode 106. 从中序与后序遍历序列构造二叉树(Construct Binary Tree from Inorder and Postorder Traversal)

    目录 题目描述: 示例: 解法: 题目描述: 根据一棵树的中序遍历与后序遍历构造二叉树. 注意: 你可以假设树中没有重复的元素. 示例: 给出 中序遍历 inorder = [9,3,15,20,7] ...

  2. 传智播客Springmvc_mybatis学习笔记

    文件地址:https://download.csdn.net/download/qq_26078953/10614459

  3. Eclipse的一下设置

    一.设置自动补全 1.打开 Eclipse -> Window(窗口) -> Perferences(首选项) 2.点开java->Editor(编辑器)->Content A ...

  4. 最大子树和 树形dp

    题目描述 小明对数学饱有兴趣,并且是个勤奋好学的学生,总是在课后留在教室向老师请教一些问题.一天他早晨骑车去上课,路上见到一个老伯正在修剪花花草草,顿时想到了一个有关修剪花卉的问题.于是当日课后,小明 ...

  5. 23.3Sum(三数和为零)

    Level:   Medium 题目描述: Given an array nums of n integers, are there elements a, b, c in nums such tha ...

  6. Qt 学习之路 2(73):Qt 线程相关类

    Home / Qt 学习之路 2 / Qt 学习之路 2(73):Qt 线程相关类 Qt 学习之路 2(73):Qt 线程相关类  豆子  2013年11月26日  Qt 学习之路 2  7条评论 希 ...

  7. C++_类入门3-嵌套类

    可以将类B声明在另一个类中.在另一个类A中声明的类B被称为嵌套类(nested class). 类A的成员函数可以创建和使用嵌套类B的对象. 当且仅当声明为公有部分时,才能在类A的外面使用嵌套类.而且 ...

  8. 洛谷 P1800 software_NOI导刊2010提高(06)

    题目链接 题解 二分答案+dp 如果我们知道答案,贪心地想,让每个人做尽量多的模块一定不会比最优解差 \(f[i][j]\)表示前\(i\)个人第一个模块做了\(j\)块,第二个模块最多能做多少 然后 ...

  9. HDU_1430 魔板 【BFS+康托展开+置换】

    一.题面 POJ1430 二.分析 该题与之前做的八数码不同,它是一个2*4的棋盘,并且没有空的区域.这样考虑的情况是很少的,依然结合康托展开,这时康托展开最多也只乘7的阶乘,完全可以BFS先预处理一 ...

  10. php session_id() session_name()

    1.Session.use_cookies:默认值为"1",代表SessionID使用Cookie来传递,反之就是用Query_String来传递 2.Session.name:这 ...