原创jquery插件treeTable(转)

     由于工作需要,要直观的看到某个业务是由那些子业务引起的异常,所以我需要用树表的方式来展现各个层次的数据。

需求:

         1、数据层次分明;

         2、数据读取慢、需要动态加载孩子节点;

         3、支持默认展开多少层。

     在网上找到了很多资料,发现treeTable方面的组件质量都不高,有些还不错样式不符合,性能也比较差。想想树表也挺简单的,不就是通过隐藏或者展现某些tr来实现嘛。于是乎,自己写一个。

 

      2011年5月4号恰好放假一个下午,于是在家里风风火火开始构造自己的树表插件。

      样式我就用了http://www.hanpau.com/index.php?page=jqtreetable,包括图片以及参数命名都借鉴了。但这款插件质量不怎样,使用方式很麻烦,效率低。

 

一、使用接口

     个人觉得,接口这部分是一款插件是否好用的核心。

 

  jqTreeTable的用法:

 

  html结构

Html代码  收藏代码
  1. <span style="font-size: small;"><table id="id">  
  2. <tr><td>1</td></tr>  
  3. <tr><td>2</td></tr>  
  4. <tr><td>3</td></tr>  
  5. <tr><td>4</td></tr>  
  6. </table></span>  

 

  js调用

Js代码  收藏代码
  1. <span style="font-size: small;">var map = [0, 1, 1, 0, 4, 5];  
  2. var options = {};  
  3. $("#id").jqTreeTable(map, options);</span>  

 

  这个使用方式比较麻烦,后台不仅要构造html,而且还要构造出map的数组。

 

 

 所以,我自己的组件改造了这种结构,如下:

 

   html结构

Html代码  收藏代码
  1. <span style="font-size: small;"><table id="id">  
  2. <tr id="1"><td>1</td></tr>  
  3. <tr id="2" pId="1"><td>2</td></tr>  
  4. <tr id="3" pId="1"><td>3</td></tr>  
  5. <tr id="4" pId="3"><td>4</td></tr>  
  6. </table></span>  

 

   js调用

Js代码  收藏代码
  1. <span style="font-size: small;">var options = {};  
  2. $("#id").jqTreeTable(options);</span>  

 

    我这种方式只需要构造html,把父子关系当作自定义属性放在html中,使用相对方便。(注意:我刚开始是使用 key="1" pKey="2"的方式来标识一行的数据,以及行之间的关系,但想到以后通过自定义属性key来选择行效率比较低,所以改为id来存储行的唯一标识。)

 

二、html的格式

    在jqTreeTable中:

 

    扣红的html对应的格式是:

Html代码  收藏代码
  1. <span style="font-size: small;"><tr>  
  2. <td>6</td>  
  3. <td>  
  4. <img src="../images/vertline.gif" class="preimg">  
  5. <img src="../images/vertline.gif" class="preimg">  
  6. <img src="../images/blank.gif" class="preimg">  
  7. <img src="../images/tv-collapsable.gif" class="parimg" id="treet16">Child of 4  
  8. </td>  
  9. <td>[0, 2, 3, 4, 6]&nbsp;</td>  
  10. <td>4</td>  
  11. <td>[7]</td>  
  12. </tr></span>  

 

 这里有两个问题:

  1、都用图片在网速慢的情况时会产生很多图片占用符...,不好看。

  2、直接用图片会产生很多小图片,且不能合并。

 

以下是我优化的结构:

 

Html代码  收藏代码
  1. <span style="font-size: small;"><tr>  
  2.     <td>6</td>  
  3.     <td>  
  4.         <span class="pre_span">  
  5.             <span class="vertline"></span>  
  6.             <span class="vertline"></span>  
  7.             <span class="blank"></span>  
  8.             </span>  
  9.         <span class="collapsable"></span>  
  10.          Child of 4  
  11.     </td>  
  12.     <td>[0, 2, 3, 4, 6]&nbsp;</td>  
  13.     <td>4</td>  
  14.     <td>[7]</td>  
  15. </tr></span>  

 

 这样解决了上述问题:

1、在网速慢的情况时只不过看不到背景,可不会出现图片占用符。

2、使用背景偏移的方式,可以把小图片合并在同张图片中。

 

三、原创treeTable的实现

基本逻辑

1、展开节点的图标有分最后一个跟非最后一个,例如:展开节点时最后一个的展开和最后一个的展开。(需要isLastOne)

2、如果父节点是最后一个节点,则前缀加,如果父节点不是最后一个节点,则前缀加。(需要isLastOne、hasChild)

3、如果有孩子,则显示+或-号,如果没有则是普通的叶子节点。(需要hasChild)

4、有孩子的节点点击则展开或者隐藏相应的子节点。(需要hasChild)
5、如果存在前一个兄弟节点,则使用节点的前缀图标,若不存在则用父节点的图标。(需要isFirstOne)
 

实现过程

1、在html中,我只是把父子节点的关系写在自定义属性,但对于节点是否有孩 子(hasChild),是否是最后一个节点(isLastOne),是否是第一个节点(isFirstOne),都还不知道。所以第一步要分析出这些信 息,把这些信息都记录到自定义属性。【注意:这些信息其实也可以记录到DOM对象的自定义属性中,但DOM对象的自定义属性无法在生成html的时候初始 化,所以不采用。】

2、先扫描所有的tr,构造出两个map,分别记录{'pId' => ['id1', 'id2']}和{id => pId}的关系。

3、再次扫描所有的tr,根据两个map的关系,给tr增加hasChild、isLastOne、isFirstOne等自定义标签,并开始构造节点图标。

4、给整个table增加点击事件监控,如果是来自(hasChild)的父节点则进行点击事件。【亮点:jqTreeTable是给每个图标都绑定事件,而我是给整个table绑定一个点击事件,提高性能。】

 

最后效果:

 

 

 

5月4号那天,花了下午完成基本功能,晚上一直自主加班到1点完善功能和优化性能,包括使用span替换img,使用table整体的点击事件等。为自己的执着而加班,最后效果还比较满意。还差将图片合并成一张,再改改css,就ok了。

 

 

 

原创jquery插件treeTable v1.1

这个版本提高了性能,做了以下改进:

 

* 1、使用了Css Sprite Tools 合并了分散的图标

* 2、使用了.id的方式来代替原来[pId=id],这样选择孩子效率更高

* 3、把css剥离出来,增加动态添加css,每次家在前判断是否添加过

 

关于第二点,非常感谢onli同学的提醒。但我并没有直接修改我的接口,直接除去pId,而是在第一次遍历时将pId作为class名添加到节点中。这样有两个好处:

(1)接口可读性会比较好,pId比class更容易理解。

(2)第二点,如果直接使用class,那节点本来就有样式,这样获取到的className还要去分解空格得到pId,挺麻烦的。

 

 

原创jquery插件treeTable V1.3

这个版本扩展了事件,做了以下改进:

* 1、增加onSelect事件,onSelect: function($treeTable, id){}

* 2、增加beforeExpand事件,beforeExpand : function($treeTable, id){}

 

动态加载节点就靠beforeExpand 事件了。

 

 

原创jquery插件treeTable V1.4.2

这个版本修复了bug,做了以下改进:

 

* 1、修复了多个tableTree不在同个页面的bug,并且可以让不同的tableTree使用不同的主题。

* 2、增加了controller的自定义标签来控制可点击的区域。

 

 

 转:http://zhanchaojiang.iteye.com/blog/1036454

 

  • treeTable.rar (35.1 KB)
  • 描述: treeTable V1.0
  • 下载次数: 210
  • treeTable_V1.1.rar (28.8 KB)
  • 下载次数: 54
  • treeTable_v1.3.rar (29.5 KB)
  • 下载次数: 87
  • treeTable_v1.4.2.rar (42.6 KB)
  • 下载次数: 716

转载于:https://www.cnblogs.com/zhoujg/archive/2013/04/24/3039486.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/248569.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

初探Vue3

&#x1f31c;本篇文章目录\textcolor{green}{本篇文章目录}本篇文章目录 &#x1f31b; &#x1f435; 新构建工具Vite\textcolor{blue}{新构建工具Vite}新构建工具Vite &#x1f435; CompositionAPI火爆来袭\textcolor{blue}{Composition API火爆来袭}CompositionAPI火爆来…

linux执行python命令后permission denied

linux下执行python后显示被拒绝问题定位&#xff1a; 1、检查下要执行的文件的权限是否存在执行权限&#xff0c;否则执行chmod命令赋予权限&#xff1b; 2、若赋予权限后仍然显示没有权限&#xff0c;检查下执行的python文件是否有权限&#xff0c;否则执行chmod赋予执行权限。…

mysql zip 安装

第一步下载mysql.zip https://dev.mysql.com/downloads/mysql/5.7.html#downloads 第二步&#xff1a;解压文件后在其目录下&#xff0c; 新建 my.ini 注意编码为ansi&#xff0c;新建 data 空文件夹 my.ini内容为&#xff1a; [mysql]# 设置mysql客户端默认字符集default…

react Native 环境安装配置——图解版一目了然

✨原创不易&#xff0c;还希望各位大佬支持一下\textcolor{blue}{原创不易&#xff0c;还希望各位大佬支持一下}原创不易&#xff0c;还希望各位大佬支持一下 &#x1f525; Flutter和reactNative的区别\textcolor{green}{Flutter和react Native的区别}Flutter和reactNative的…

第七章 字典和集合[DDT书本学习 小甲鱼]【2】

7.1.2 字典的各种内置方法在序列里为不存在位置赋值&#xff0c;会出现错误&#xff1b;而在字典不存在得位置赋值&#xff0c;会创建。工厂函数&#xff08;类型&#xff09;以前学过 str(),int(),list(),tuple()....... 1.fromkeys() 用于创建和返回一个新的字典 不是修改 2…

Installing Node.js and Express on Ubuntu

Installing Node.js and Express on Ubuntu 1. 在nodejs官网上下载Linux Binaries(已经包含了npm):2. 安装Node.js下载后解压&#xff0c;并在解压的文件夹中启动Terminal后&#xff0c;输入命令&#xff1a; sudo cp * /usr/local/ -r再输入命令&#xff1a; node -v …

Chrome插件我只服你——10w人都在使用的浏览器插件

✨文章摘要导读\textcolor{blue}{文章摘要导读}文章摘要导读 &#x1f525; 为什么选择Chrome插件\textcolor{green}{为什么选择Chrome插件}为什么选择Chrome插件 &#x1f525; 插件具备的强大优势\textcolor{green}{插件具备的强大优势}插件具备的强大优势 &#x1f525; …

H3C通过端口ID决定端口角色

转载于:https://www.cnblogs.com/fanweisheng/p/11153312.html

特殊属性

转载于:https://www.cnblogs.com/mengbin0546/p/10338371.html

一款超强的手机屏幕投影工具

✨文章摘要导读\textcolor{blue}{文章摘要导读}文章摘要导读 &#x1f525; 前言\textcolor{green}{前言}前言 &#x1f525; 准备工作\textcolor{green}{准备工作}准备工作 &#x1f525; Scrcpy安装\textcolor{green}{Scrcpy安装}Scrcpy安装 &#x1f525; 工具调试\text…

JS一维数组转化为三维数组有这个方法就够了

今天在CSDN上问答区看到一个提问的小伙伴&#xff0c;是想要将一维数组转化为三位数组的需求&#xff0c;正好不是很忙&#xff0c;乐于助人的我立马给这位同学安排上 下面是后端同学返给我们的一维数组数据格式 [{品牌: xiaomi, 机型: 10, 配置: 512},{品牌: xiaomi, 机型: 10…

Day 21 20190205 老男孩python学习第21天 内容整理

今天写作业&#xff0c;明天后天要在外旅游 写作业写了7个小时。 1 def read_file_as_dict(where):2 staff_dict {}3 f open(%s % where, mode"r", encodingutf-8)4 data f.read()5 f.close()6 row data.strip().split(\n)7 for staff i…

SCOM 简单界面操作指南 [SCOM中文系列之三]

今天大概介绍下SCOM的管理界面&#xff0c;大概分三个重要的功能版块 Monitoring 监控版面 Authoring &#xff08;中文版不知道翻译成什么&#xff0c;主要编辑MP&#xff09; Administration 管理操作 首先说一下管理操作区&#xff0c;开始装好的SCOM都需要来这里配置一下的…

趁着对象泡脚的功夫,我把vueX吃透了

文章目录vueX&#x1f31f;Vuex的概述什么是vuexVuex管理数据的优点&#x1f31f;Vuex的基本使用步骤1.安装 npm i vuex --save2.在src文件目录下新建store>index.js文件3.口文件里面引入store&#xff0c;然后再全局注入4.使用&#x1f31f;Vuex中的核心特性State在组件中访…

【题解】FBI序列

题目描述 两伙外星人策划在未来的XXXX年侵略地球&#xff0c;侵略前自然要交换信息咯&#xff0c;现在&#xff0c;作为全球保卫队队长&#xff0c;你截获了外星人用来交换信息的一段仅由“F”&#xff0c;“B”&#xff0c;“I”&#xff0c;“O”组成的序列。为了保卫地球和平…

vue基础(上篇)

✨有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于vue的基础篇\textcolor{blue}{ 有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于 vue的基础篇}有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于vue的基础篇 ✨ 今天他来了…

depends用于测试程序运行所缺少的文件,可以帮我们很快找到问题

DEPENDS工具和DUMPBIN工具使用阅读目录(Content) 1.Depends2.DUMPBIN2.1 开启CMD2.2 移动目录到C:\Program Files (x86)\Microsoft Visual Studio\VC98\Bin2.3 运行命令:VCVARS32.BAT2.4 下面就可以调用dumpbin.exe命令了在系统部署运行时我们经常发现某个程序在开发机器中可以…

友联

欢迎来到小站友链区&#xff0c;欢迎━(&#xff40;∀)ノ亻!。 ljc20020730学长巨佬_WA自动机珂朵莉最可爱了BLUESKY007雷姆最可爱啦扬子曰他的代码是神奇的lukelin机房最强如果你想要成为chhokmah小站的朋友的话&#xff0c;请你先把小站加入为友链站哟(&#xff3e;&#xf…

vue基础(中篇)

✨有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于vue的基础篇\textcolor{blue}{ 有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于 vue的基础篇}有粉丝在私信中联系博主&#xff0c;希望博主能够系统的出一篇关于vue的基础篇 ✨ 今天他来了…

DR图像的畸变校正

DR图像容易产生S形、枕形和局部失真的情况&#xff0c;这给医生对图像的判断带来干扰。而且在医学图像的三维重建中&#xff0c;未经校正的图像进行重建&#xff0c;还会带来一定的重影等干扰。因此&#xff0c;畸变校正是DR图像进行后续处理&#xff0c;不得不对待的一个问题。…