一.AdminLTE介绍

1.介绍

​ AdminLTE是一个开源的后台控制面板和仪表盘 WebApp 模板,是建立在Bootstrap3框架和JQuery之上的开源模板主题工具,它提供了一系列响应的组件,并内置了多个模板页面,包括仪表盘、邮箱、日历、锁屏、登录及注册、404错误、500错误等页面。通过AdminLTE,我们可以快速的创建一个响应式的Html5网站。

2.下载

我们可以到其官网下载:https://adminlte.io/

也可选择中文版本的地址:http://adminlte.la998.com/index2.html

其中有一些模板是收费的,当然也有挺多免费的,看需求自行选择。

3.AdminLTE的简单使用

​ AdminLTE的使用并不难,和使用Bootstrap类似。我们将下载的文件导入到我们的工程当中,进行适当的删改即可。当然,我们也可以只使用其中的一小部分,甚至是一个小组件。详见其官方文档:

中文文档:http://adminlte.la998.com/documentation/#introduction

二.zTree的简单使用

1.简介

​ zTree 是一个依靠 jQuery 实现的多功能 “树插件”。优异的性能、灵活的配置、多种功能的组合是 zTree 最大优点。专门适合项目开发,尤其是 树状菜单、树状数据的 Web 显示、权限管理等等。

特点

  • zTree v3.0 将核心代码按照功能进行了分割,不需要的代码可以不用加载。

  • 采用了延迟加载技术,上万节点轻松加载,即使在 IE6 下也能基本做到秒杀。

  • 兼容 IE、FireFox、Chrome、Opera、Safari 等浏览器。

  • 支持 JSON 数据。

  • 支持静态和 Ajax 异步加载节点数据。

  • 支持任意更换皮肤 / 自定义图标(依靠 css)。

  • 支持极其灵活的 checkbox 或 radio 选择功能。

  • 提供多种事件响应回调。

  • 灵活的编辑(增/删/改/查)功能,可随意拖拽节点,还可以多节点拖拽哟。

  • 在一个页面内可同时生成多个 Tree 实例。

  • 简单的参数配置实现 灵活多变的功能。

2.基本使用

第一步:导入zTree组件

<link rel="stylesheet" href="${ctx }/components/zTree/css/zTreeStyle/zTreeStyle.css" type="text/css" />
<script type="text/javascript" src="${ctx }/components/zTree/js/jquery-1.4.4.min.js"></script>
<script type="text/javascript" src="${ctx }/components/zTree/js/jquery.ztree.core-3.5.min.js"></script>
<script type="text/javascript" src="${ctx }/components/zTree/js/jquery.ztree.excheck-3.5.min.js"></script>

第二步:编写页面

script

<script type="text/javascript">
// 1.设置树的配置信息
var setting = {
check: { // 复选框可用
enable: true
},
data: { // 定义使用简单json数据格式,如下所示:
simpleData: {
enable: true
}
}
};
/** 简单json数据格式:
* [{ id:11, pId:1, name:"系统", checked:true}, { id:12, pId:1, name:"财务",checked:false}]
* 当前项id 父项id 名称 是否勾选
*/ // 2.页面加载完毕后发起异步请求获得json格式的数据
$(document).ready(function(){
$.get("${ctx}/system/role/initModuleData.do?roleid=${role.id}",function(data) {
initZtree(data);
},"json");
}); // 3.定义zTree树
var zTreeObj;
// 4.根据获取到的json数据展示ztree树
function initZtree(data) {
//第一个参数:树显示的位置,第二个参数:树的配置信息,第三个参数:要展示的数据
zTreeObj = $.fn.zTree.init($("#treeDemo"), setting, data);
zTreeObj.expandAll(true);//true:展开所有节点
} // 5.实现权限分配(zTree树复选框提交时)
function submitCheckedNodes() {
//1.获取所有的勾选权限节点
var nodes = zTreeObj.getCheckedNodes(true);//true:被勾选,false:未被勾选
//2.循环nodes,获取每个节点的id, 拼接模块字符串(以,分隔)
var moduleIds = "";
for(var i=0;i<nodes.length;i++) {
moduleIds += nodes[i].id +",";
}
if(moduleIds.length>0) {
//substr : 字符串剪切 0 :起始位置, 第二个参数:最大长度
//123456789, 0 9
moduleIds = moduleIds.substr(0,moduleIds.length-1);
}
$("#moduleIds").val(moduleIds); // 设置表单隐藏域的值
$("#icform").submit(); // 提交表单
}
</script>

树菜单

<!-- 树菜单 -->
<form name="icform" id="icform" method="post" action="${ctx}/system/role/updateRoleModule.do">
<input type="hidden" name="roleid" value="${role.id}"/>
<input type="hidden" id="moduleIds" name="moduleIds" value=""/>
<div class="content_wrap">
<div class="zTreeDemoBackground left" style="overflow: visible">
<!-- 展示zTree树的地方 -->
<ul id="treeDemo" class="ztree"></ul>
</div>
</div>
</form>
<!-- 树菜单 /-->

第三步:Controller返回正确的json格式数据

Tips: 分析页面所需json数据格式为:

[{ id:11, pId:1, name:"系统", checked:true}, { id:12, pId:1, name:"财务",checked:false}]

因此可以将数据查出来后自行转为json格式的。也可通过sql语句直接查出我们所需要的数据格式:

<!-- 查找角色权限的功能模块(一条语句,包含所有模块及当前角色的模块权限标记)注意返回的是map类型 -->
<select id="findTreeJson" parameterType="string" resultType="map">
select
module_id as id ,
parent_id as pId,
name as name,
case when module_id in (select module_id from pe_role_module where role_id = #{roleId})
then 'true'
else 'false'
end
as checked
from ss_module;
</select>

Controller返回json数据

//页面加载完毕后直接发起异步请求初始化 权限菜单树
@RequestMapping(value = "/initModuleData",name = "加载角色权限")
public @ResponseBody List initModuleData(@RequestParam("roleid") String id){
List<Map> list = roleService.findTreeJson(id);
return list;
}

这样,页面就可以根据我们的json数据动态的生成一个zTree树啦!

喜欢的朋友可以关注我的公众号,需要广告托管的朋友可以加QQ哦!

AdminLTE介绍和zTree的简单使用的更多相关文章

  1. WeX5的简单介绍及UI的简单讲解

    WeX5的简单介绍及UI的简单讲解 (2016-01-13 14:49:05) 标签: it 分类: WeX5的初步自学 一.WeX5的简单讲解 1.WeX5是前端快速开发框架,可开发跨端运行应用.是 ...

  2. Ztree的简单使用和后台交互的写法(二)

    针对Ztree的简单使用和后台交互的写法(一)中的树进行改进 1.增加节点的权限 由页面的当前用户,决定树的根节点 然后动态获取树的详细节点: 初始化函数为: function init(){ //初 ...

  3. Node.js简单介绍并实现一个简单的Web MVC框架

    编号:1018时间:2016年6月13日16:06:41功能:Node.js简单介绍并实现一个简单的Web MVC框架URL :https://cnodejs.org/topic/4f16442cca ...

  4. 项目中简单使用ztree,简单数据。

    由于公司架构较旧,使用的jdk版本为1.4,页面上也没有el表达式. 加入 js 文件 <% String context = request.getContextPath(); %> & ...

  5. iOS边练边学--多线程介绍、NSThread的简单实用、线程安全以及线程之间的通信

    一.iOS中的多线程 多线程的原理(之前多线程这块没好好学,之前对多线程的理解也是错误的,这里更正,好好学习这块) iOS中多线程的实现方案有以下几种 二.NSThread线程类的简单实用(直接上代码 ...

  6. Ztree学习(-)简单例子

    https://www.cnblogs.com/shinhwazt/p/5828031.html ztree包:https://pan.baidu.com/s/1vOgGm_elF-lF0VowoHw ...

  7. MQTT介绍(1)简单介绍

    MQTT目录: MQTT简单介绍 window安装MQTT服务器和client java模拟MQTT的发布,订阅 MQTT: MQTT(Message Queuing Telemetry Transp ...

  8. zTree的简单使用

    理论可以看:http://www.cnblogs.com/shinhwazt/p/5828031.html zTree包:链接:http://pan.baidu.com/s/1eR4xP6M 密码:w ...

  9. 什么是Cookie。Cookie的原理介绍,Cookie的简单应用

    1 介绍:Cookies亦称Cookie .Cookies是一种能够让网站服务器把少量数据储存到客户端的硬盘或内存,或是从客户端的硬盘读取数据的一种技术.Cookies是当你浏览某网站时,由Web服务 ...

随机推荐

  1. 阿里云服务器Ubuntu 16.04 3安装mysql

    .更新系统 apt-get update [注意:要在root用户下] .安装mysql-server apt-get install mysql-serverapt-get install mysq ...

  2. Maven学习总结(29)——Maven项目的pom.xml中log4j2配置

        <dependency>         <groupId>org.apache.logging.log4j</groupId>         <a ...

  3. [luoguP3203][HNOI2010]BOUNCE 弹飞绵羊(LCT)

    传送门 每个点都会跳到另一个点,连边就是一棵树. 更改弹力就是换边. 求一个点跳多少次跳到终点就是求这个点的深度,那么只需要维护 size 域,access(n + 1) 然后 splay(x),求 ...

  4. B树、B-树、B+树、B*树介绍,和B+树更适合做文件索引的原因

    今天看数据库,书中提到:由于索引是采用 B 树结构存储的,所以对应的索引项并不会被删除,经过一段时间的增删改操作后,数据库中就会出现大量的存储碎片, 这和磁盘碎片.内存碎片产生原理是类似的,这些存储碎 ...

  5. - > 动规讲解基础讲解五——最长公共子序列问题

    一些概念: (1)子序列: 一个序列A = a1,a2,……an,中任意删除若干项,剩余的序列叫做A的一个子序列.也可以认为是从序列A按原顺序保留任意若干项得到的序列. 例如:   对序列 1,3,5 ...

  6. Waiting For Debugger

    在eclipse中进行调试时常常出现以下这种提示:Application  (app名称)  is waiting for the debugger to attach 正常情况下.会非常快进入应用调 ...

  7. hadoop-2.6.0 Unhealthy Nodes 问题

    近期安装hadoop-2.6.0集群时,打开8088页面,查看集群信息,看到集群出现Unhealthy Nodes 的问题,点击该处.会展开Unhealthy Nodes 的情况,这时会看到Healt ...

  8. 飞思卡尔 imx6 GC0308 摄像头驱动配置调试过程

    GC0308摄像头驱动程序使用的是linux v4l2协议,通过i2c信号进行控制.GC0308摄像头.对上电时序要求非常严格,一定要依据datasheet初始化摄像头. 本驱动使用的3.10内核,所 ...

  9. LeetCode 804. Unique Morse Code Words (唯一摩尔斯密码词)

    题目标签:String 题目给了我们 对应每一个 字母的 morse 密码,让我们从words 中 找出 有几个不同的 morse code 组合. 然后只要遍历 words,把每一个word 转换成 ...

  10. LeetCode 290. Word Pattern (词语模式)

    Given a pattern and a string str, find if str follows the same pattern. Here follow means a full mat ...