热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

浅谈Bootstraptable中父子表和行列调序的用法

web前端|js教程bootstraptableweb前端-js教程本篇文章结合Bootstraptable的父子表和行列调序的用法,再来介绍下它稍微高级点的用法织梦文库源码,ub

web前端|js教程浅谈Bootstrap table中父子表和行列调序的用法
bootstrap table
web前端-js教程
本篇文章结合Bootstrap table的父子表和行列调序的用法,再来介绍下它稍微高级点的用法
织梦文库源码,ubuntu 查看支持包,爬虫技术哪种最好,php添加tocken,网页seo slzw
asp后台管理系统源码,vscode插件保存在哪里,ubuntu 网卡管理,tomcat缓存存放位置,爬虫天龙星,西安php工资,重庆seo推广优化多少钱,织梦开发网站lzw
A、效果展示
3d折线图制作源码,VScode出现prn,blcr ubuntu,bat重启tomcat,sqlite3远程连接,织梦批量添加会员插件,2017比较好的前端框架,爬虫为什么需要头部呼吸,java md5 php,zfh1234567SEO,个人网站导航模板下载,网页 筛选 代码,h5网页工业感模板lzw
今天稍微改变下方式,先来看看实现效果,后面再介绍代码实现及注意事项。来,效果图来一发:

1、父子表效果图

浅谈Bootstrap table中父子表和行列调序的用法

浅谈Bootstrap table中父子表和行列调序的用法

浅谈Bootstrap table中父子表和行列调序的用法

2、行调序

调序前

浅谈Bootstrap table中父子表和行列调序的用法

拖动行调序到第一行

浅谈Bootstrap table中父子表和行列调序的用法

3、列调序

调序前

浅谈Bootstrap table中父子表和行列调序的用法

拖动列标题调序

浅谈Bootstrap table中父子表和行列调序的用法

调序后

浅谈Bootstrap table中父子表和行列调序的用法

B、父子表代码详解

上章我们介绍Bootstrap table基础用法的时候介绍过,初始化表格的时候有一个属性“detailView”,将它设置为true,在每行的前面即可看到一个“+”形状的图标。点击这个图标即触发加载子表格的事件。大概的原理就是如此,来看看代码,其实也很简单。

1、初始化表格,注册行展开事件

      $("#tb_powerset").bootstrapTable({url: '/api/MenuApi/GetParentMenu',method: 'get',detailView: true,//父子表//sidePagination: "server",pageSize: 10,pageList: [10, 25],columns: [{ field: 'MENU_NAME', title: '菜单名称'}, { field: 'MENU_URL', title: '菜单URL'}, { field: 'PARENT_ID', title: '父级菜单'}, { field: 'MENU_LEVEL', title: '菜单级别'}, ],//注册加载子表的事件。注意下这里的三个参数!onExpandRow: function (index, row, $detail) { oInit.InitSubTable(index, row, $detail);} });

还是来看看子表加载事件onExpandRow对应方法function (index, row, $detail)的三个参数,

index:父表当前行的行索引。

row:父表当前行的Json数据对象。

$detail:当前行下面创建的新行里面的td对象。

第三个参数尤其重要,因为生成的子表的table在装载在$detail对象里面的。bootstrap table为我们生成了$detail这个对象,然后我们只需要往它里面填充我们想要的table即可。

2、我们来看oInit.InitSubTable()这个方法

//初始化子表格(无线循环) oInit.InitSubTable = function (index, row, $detail) { var parentid = row.MENU_ID; var cur_table = $detail.html('

').find('table'); $(cur_table).bootstrapTable({ url: '/api/MenuApi/GetChildrenMenu', method: 'get', queryParams: { strParentID: parentid }, ajaxOptions: { strParentID: parentid }, clickToSelect: true, detailView: true,//父子表 uniqueId: "MENU_ID", pageSize: 10, pageList: [10, 25], columns: [{checkbox: true }, {field: 'MENU_NAME',title: '菜单名称' }, {field: 'MENU_URL',title: '菜单URL' }, {field: 'PARENT_ID',title: '父级菜单' }, {field: 'MENU_LEVEL',title: '菜单级别' }, ], //无线循环取子表,直到子表里面没有记录 onExpandRow: function (index, row, $Subdetail) {oInit.InitSubTable(index, row, $Subdetail); } }); };

由此可以看出生成子表的原理就是创建一个table对象cur_table,然后再注册这个对象的表格初始化即可。是不是很简单~~

C、行调序代码详解

行调序的代码就更简单了,来看看。

1、需要额外引用两个js文件

2、在cshtml页面定义表格时,添加两个属性

然后js表格初始化的时候不需要做任何修改,加载出来的表格即可实现行调序的功能。

D、列调序代码详解

和行调序类似。列调序的使用如下:

1、额外引用几个js和css

2、在cshtml页面定义表格时,添加一个属性

其他地方不用做任何修改。加载出来的表格即可实现列调序。有没有很简单。

E、控件过滤

本来这篇准备结束的,突然想起上章里面有一个搜索的功能,好像是服务端分页的时候搜索功能没法使用,于是想起之前再CS里面做过一个类似每个列过滤的功能,博主好奇心又起来了,bootstrap table是否也有这种表格每列过滤的功能,于是查看文档。结果不负所望,还真有~~我们来看看。

1、效果图展示

浅谈Bootstrap table中父子表和行列调序的用法

浅谈Bootstrap table中父子表和行列调序的用法

浅谈Bootstrap table中父子表和行列调序的用法

浅谈Bootstrap table中父子表和行列调序的用法

2、代码示例

(1)引入额外js

(2)定义表格属性及表头属性

  

角色名称角色描述角色默认页面

因为这里定义了表头的属性,所以,js初始化的时候就不用定义列了。

(3)js初始化

$('#tb_roles').bootstrapTable({ url: '/Role/GetRole', method: 'get', toolbar: '#toolbar', striped: true, cache: false, striped: true, pagination: true, sortable: true, queryParams: function (param) { return param; }, queryParamsType: "limit", detailView: false,//父子表 sidePagination: "server", pageSize: 10, pageList: [10, 25, 50, 100], search: true, showColumns: true, showRefresh: true, minimumCountColumns: 2, clickToSelect: true, });

最开始,博主以为这种搜索只能用户客户端分页的情况,可是经过调试发现并非如此,原来搜索的条件都能通过json传递到服务端。我们来看调试的过程

浅谈Bootstrap table中父子表和行列调序的用法

后台接收参数,并反序列化

浅谈Bootstrap table中父子表和行列调序的用法

这样我们就能将查询的条件很好地传递到后台。很好很强大啊。这样就免去了扩展表格搜索功能的烦恼~~

F、总结

以上就是bootstrap table的一些扩展应用。可能未不全面,还有一些高级用法也没有介绍,比如行、列合并,行列冻结等等。但博主相信只要有文档,使用起来应该问题不大。源码还需整理,待整理好再发上来。园友们暂且先看看!!

编程入门!!


推荐阅读
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • 本章将深入探讨移动 UI 设计的核心原则,帮助开发者构建简洁、高效且用户友好的界面。通过学习设计规则和用户体验优化技巧,您将能够创建出既美观又实用的移动应用。 ... [详细]
  • JavaScript 中创建对象的多种方法
    本文详细介绍了 JavaScript 中创建对象的几种常见方式,包括对象字面量、构造函数和 Object.create 方法,并提供了示例代码和属性描述符的解释。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • 本文详细介绍了如何在Ubuntu系统中下载适用于Intel处理器的64位版本,涵盖了不同Linux发行版对64位架构的不同命名方式,并提供了具体的下载链接和步骤。 ... [详细]
  • 本文介绍如何通过SSH协议使用Xshell远程连接到Ubuntu系统。为了实现这一目标,需要确保Ubuntu系统已安装并配置好SSH服务器,并保证网络连通性。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 深入解析 Spring Security 用户认证机制
    本文将详细介绍 Spring Security 中用户登录认证的核心流程,重点分析 AbstractAuthenticationProcessingFilter 和 AuthenticationManager 的工作原理。通过理解这些组件的实现,读者可以更好地掌握 Spring Security 的认证机制。 ... [详细]
  • PHP 时间与日期工具类:星座、干支、生肖的实现
    本文介绍了一个PHP时间与日期工具类,涵盖了时区设置、有效日期和时间检查、星座、干支、生肖计算等功能。该工具类特别适用于需要处理中国农历及西方星座的应用场景。 ... [详细]
  • 选择适合生产环境的Docker存储驱动
    本文旨在探讨如何在生产环境中选择合适的Docker存储驱动,并详细介绍不同Linux发行版下的配置方法。通过参考官方文档和兼容性矩阵,提供实用的操作指南。 ... [详细]
  • 在创建新的Android项目时,您可能会遇到aapt错误,提示无法打开libstdc++.so.6共享对象文件。本文将探讨该问题的原因及解决方案。 ... [详细]
  • 嵌入式开发环境搭建与文件传输指南
    本文详细介绍了如何为嵌入式应用开发搭建必要的软硬件环境,并提供了通过串口和网线两种方式将文件传输到开发板的具体步骤。适合Linux开发初学者参考。 ... [详细]
  • 本文详细介绍了如何在PHP中进行数组删除、清空等操作,并提供了在Visual Studio Code中创建PHP文件的步骤。 ... [详细]
  • 在PHP后端开发中遇到一个难题:通过第三方类文件发送短信功能返回的JSON字符串无法解析。本文将探讨可能的原因并提供解决方案。 ... [详细]
author-avatar
zc163com
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有