由简入繁实现Jquery树状结构的方法(推荐)


Posted in Javascript onJune 10, 2016

在项目中,我们经常会需要一些树状结构的样式来显示层级结构等,比如下图的样式,之前在学.net的时候可以直接拖个服务端控件过来直接使用非常方便。但是利用Jquery的一些插件,也是可以实现这些效果的,比如说Jquery.treeview.js插件。

由简入繁实现Jquery树状结构的方法(推荐)

下面就直入主题,开始从简入繁的分析怎么使用treeview插件,从已知的知识开始轻松入手,让树状结构唾手可得。 

显示树状结构的几个实现步骤:

一、HTML做初始静态原型。

首先通过<ul></ul><li></li>展示树状基本结构,还原其最初的样子:

相信学过一点HTML的同学都可以实现吧,在“tree.html”中写如下代码:

<ul>
    <li>系统管理
      <ul>
        <li>部门管理</li>
        <li>岗位管理
          <ul>
            <li>岗位添加</li>
            <li>岗位删除</li>
          </ul>
        </li>
        <li><用户管理
          <ul>
            <li>添加用户</li>
            <li>修改用户</li>
          </ul>
        </li>
      </ul>
    </li>
    <li>审批流转</li>
  </ul>

我们静态的树形结构的草本如下:

由简入繁实现Jquery树状结构的方法(推荐)

二、加入treeview插件库,实现动态树状结构。

在有了基本静态的树状模型以后,我们需要实现一个动态的结构,那么,我们的大菜就要上场了。

1、首先搜索Jquery.treeview.js插件进行下载,或直接进入下面的网址进行下载插件包:

http://bassistance.de/jquery-plugins/jquery-plugin-treeview/

2、下载压缩包解压到相应文件夹内,将之间的静态页面tree.html放到根目录下:

由简入繁实现Jquery树状结构的方法(推荐)

3、在tree.html中导入js和css文件。

<!-- 导入js和CSS-->
<link rel="stylesheet" href="jquery.treeview.css" />
<script src="lib/jquery.js" type="text/javascript"></script>
<script src="lib/jquery.cookie.js" type="text/javascript"></script>
<script src="jquery.treeview.js" type="text/javascript"></script>

4、使用<ul>展示数据,为了方便得到树,在最外边的<ul>标签里加入Id为tree,如下

由简入繁实现Jquery树状结构的方法(推荐)

5、显示我们的树状结构(加上行为)。

在js里,我们只需要一行代码:

在<ul></ul>标签下加入js代码:

<script type="text/javascript">  $("#tree").treeview();  </script>

我们的动态的树状结构的初步样式如下,已经可以自由的收起和展示了:

由简入繁实现Jquery树状结构的方法(推荐)

6、显示树状结构(加上样式)。

上面的样式离我们最初想要的结果还差一点样式,比如说各项之前的文件夹图标。下面我们可以加上样式,从而完成整个树状结构的展示。

6.1在树的根节点<ul>标签中加入 class="filetree"。

6.2在各项节点前加入文件夹<span>标签:比如:<span class="folder">系统管理</span>。

整体tree.html代码如下:

<!DOCTYPE html pageEncoding="utf-8">
<html>
 <head>
  <title>tree.html</title>
  
  <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  <meta http-equiv="description" content="this is my page">
  <meta http-equiv="content-type" content="text/html; charset=GB2312">
  <!-- 导入js和CSS-->
  <link rel="stylesheet" href="jquery.treeview.css" />
  <script src="lib/jquery.js" type="text/javascript"></script>
  <script src="lib/jquery.cookie.js" type="text/javascript"></script>
  <script src="jquery.treeview.js" type="text/javascript"></script>

 </head>
 
 <body>
  <ul id="tree" class="filetree">
    <li><span class="folder">系统管理</span>
      <ul>
        <li><span class="folder">部门管理</span></li>
        <li><span class="folder">岗位管理</span>
          <ul>
            <li><span class="folder">岗位添加</span></li>
            <li><span class="folder">岗位删除</span></li>
          </ul>
        </li>
        <li><span class="folder">用户管理</span>
          <ul>
            <li><span class="folder">添加用户</span></li>
            <li><span class="folder">修改用户</span></li>
          </ul>
        </li>
      </ul>
    </li>
    <li><span class="folder">审批流转</span></li>
  </ul>
  
  <script type="text/javascript">
  $("#tree").treeview();
  </script>
 </body>
</html>

最后的样式展示:

由简入繁实现Jquery树状结构的方法(推荐)

需求完成啦!

当然树状结构的样式有多种多样,也可以实现动态的添加节点分支等等,大家可以在下载的插件里找demo文件下的例子看一下,很容易的。

第一次实现树状结构,一开始的心情有些恐惧,也是没有头绪,感觉要通过js写下一个树状结构也是有些难度的,虽说toggle方法也可以实现指定区域的收缩(隐藏)和展示,加上动态变换文件夹等图标的样式也是可以实现的,但是一想就觉得太麻烦了。所以在做OA的时候,老师提到了Jquery的treeview插件很好使,上网查询它的官方资料竟然查到了一大堆插件,作为插件控的同学们一定很兴奋吧,有一种刘姥姥进大观园的感觉。而且实现起来非常简单,从已知的知识入手,由简入繁,轻松掌握了所有Jquery插件的使用。这就是米老师说的所谓的吃饭理论吧:一个人被邀请去参加一个饭局,发现饭局中只认识那个邀请自己的人,有些人会觉得饭局很无聊,很惆怅,或退场,或自娱自乐。但是聪明的人会通过那个唯一自己认识的人而认识整个饭局的人,从而结识了一大帮朋友。我们学习也是一样的,由我们已知的知识带领我们走进未知世界,战胜恐惧和胆怯,相信没有什么实现不了事情吧。

以上这篇由简入繁实现Jquery树状结构的方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS 修改URL参数(实现代码)
Jul 08 Javascript
angularjs学习笔记之简单介绍
Sep 26 Javascript
jquery中cookie用法实例详解(获取,存储,删除等)
Jan 04 Javascript
Javascript中神奇的this
Jan 20 Javascript
JS &amp; JQuery 动态添加 select option
Jun 08 Javascript
js实现点击图片自动提交action的简单方法
Oct 16 Javascript
微信小程序 底部导航栏目开发资料
Dec 05 Javascript
JavaScript Date 知识浅析
Jan 29 Javascript
vue.js移动端app实战1:初始配置详解
Jul 24 Javascript
微信小程序下拉框组件使用方法详解
Dec 28 Javascript
Javascript如何实现双指控制图片功能
Feb 25 Javascript
Vue3配置axios跨域实现过程解析
Nov 25 Vue.js
3kb jQuery代码搞定各种树形选择的实现方法
Jun 10 #Javascript
关于网页中的无缝滚动的js代码
Jun 09 #Javascript
Document.body.scrollTop的值总为零的快速解决办法
Jun 09 #Javascript
JavaScript事件学习小结(三)js事件对象
Jun 09 #Javascript
javaScript事件学习小结(四)event的公共成员(属性和方法)
Jun 09 #Javascript
JavaScript事件学习小结(一)事件流
Jun 09 #Javascript
JavaScript事件学习小结(五)js中事件类型之鼠标事件
Jun 09 #Javascript
You might like
smarty中先strip_tags过滤html标签后truncate截取文章运用
2010/10/25 PHP
php 截取字符串并以零补齐str_pad() 函数
2011/05/07 PHP
PHP中设置时区方法小结
2012/06/03 PHP
在 Laravel 中动态隐藏 API 字段的方法
2019/10/25 PHP
实现超用户体验 table排序javascript实现代码
2009/06/22 Javascript
JS 实现Json查询的方法实例
2013/04/12 Javascript
js类型转换与引用类型详解(Boolean_Number_String)
2014/03/07 Javascript
node.js中的http.createServer方法使用说明
2014/12/14 Javascript
JavaScript实现点击自动选择TextArea文本的方法
2015/07/02 Javascript
学习JavaScript正则表达式
2015/11/13 Javascript
JS实现的颜色实时渐变效果完整实例
2016/03/25 Javascript
jQuery validate验证插件使用详解
2016/05/11 Javascript
基于jQuery实现Accordion手风琴自定义插件
2020/10/13 Javascript
JavaScript中运算符规则和隐式类型转换示例详解
2017/09/06 Javascript
elemetUi 组件--el-upload实现上传Excel文件的实例
2017/10/27 Javascript
详解angular2 控制视图的封装模式
2018/12/27 Javascript
layui输入框中只允许输入整数的实现方法
2019/09/18 Javascript
js实现时钟定时器
2020/03/26 Javascript
微信小程序拖拽排序列表的示例代码
2020/07/08 Javascript
Python图像灰度变换及图像数组操作
2016/01/27 Python
python如何对实例属性进行类型检查
2018/03/20 Python
Python实现的爬取百度贴吧图片功能完整示例
2019/05/10 Python
Python操作excel的方法总结(xlrd、xlwt、openpyxl)
2019/09/02 Python
python文件操作的简单方法总结
2019/11/07 Python
运动会解说词100字
2014/01/31 职场文书
搞笑婚礼主持词
2014/03/13 职场文书
食品安全承诺书
2014/05/22 职场文书
大学生学习面向未来的赶考思想汇报
2014/09/12 职场文书
继续教育个人总结
2015/03/03 职场文书
大学生心理健康活动总结
2015/05/08 职场文书
2015选调生工作总结
2015/07/24 职场文书
热爱劳动主题班会
2015/08/14 职场文书
2016年小学生新年寄语
2015/08/18 职场文书
小学运动会入场口号
2015/12/24 职场文书
mysql优化之query_cache_limit参数说明
2021/07/01 MySQL
Java设计模式中的命令模式
2022/04/28 Java/Android