只想简简单单画个表格,但 React,Vue,Angular,…,这么多前端框架,各自都有不同的表格渲染库。就没有表格库能“一次画表,到处运行”吗?来看看 Grid.js 这个跨框架的前端表格插件吧!

简介

Grid.js,是 Github 上 grid-js 组织开源的前端表格插件,代码仓库在 https://github.com/grid-js/gridjs,目前版本为 1.4.2。Grid.js 的标语是

A table library that works everywhere

也即是一个可以到处运行的表格库。Grid.js 没有第三方依赖锁定,其唯一的外部依赖已经被打包在内,意味着它能在所有的前端框架,包括没有框架的情况下使用。

Grid.js 使用 TypeScript 开发,大小仅为 12KB,支持所有现代浏览器,并利用内部管线技术获得了高速性能。

Grid.js表格插件

安装

在 Node.js 环境使用 Grid.js,可使用 npm 进行安装:

npm install gridjs --save

使用时需要导入 Javascript 和 CSS 文件:

import { Grid } from "gridjs";import "gridjs/dist/theme/mermaid.css";

而在浏览器环境中使用时,可以直接引用 CDN 使用:

示例

使用 Grid.js 时,需要一个 div 元素的 wrapper,然后创建一个 Grid.js 的 Grid 实例,定义表格的配置参数,最后调用 render 方法,完成渲染。

一个使用浏览器的例子如下:

      

可以看到,gridjs.Grid 使用了参数 columns 来定义列,以及 data 来添加各行的数据。类似的,Grid.js 在 React 中的例子如下:

import { Grid } from "gridjs";import "gridjs/dist/theme/mermaid.css";function helloWorld () {  const grid = new Grid({    columns: ['Name', 'Email', 'Phone Number'],    data: [      ['John', 'john@example.com', '(353) 01 222 3333'],      ['Mark', 'mark@gmail.com',   '(01) 22 888 4444']    ]  });    useEffect(() => {    grid.render(document.getElementById('wrapper'));  });    return (    

不难看出,Grid.js 的使用方法是一致的,两份代码都渲染出了美观的表格。

Grid.js表格示例

Grid.js的设计十分简洁,主要参数包括:

  • data:类型为 T[][] 或 Function,表格每行的数据。data 可以是一个包含各个单元格数据的二维数组,也可以是一个返回可解析为二维数组的函数,以实现异步加载(Promise)和动态加载。
  • from:类型为 HTMLElement,已有的 HTML 表格元素。Grid.js 可以从一个现有的 HTML 的 form 元素生成一个 Grid 表格,添加样式和其他功能。
  • server:远程数据加载。server 是一个包含 url,以及可选的 then 和 opts 的对象,可以根据从 url获取的远程数据渲染表格。
// 使用server参数进行远程数据加载const grid = new Grid({  columns: ['Title', 'Director', 'Producer'],  server: {    url: 'https://swapi.dev/api/films/',    then: data => data.results.map(movie => [movie.title, movie.director, movie.producer])  } });
  • columns:类型为string[] 或 TColumn[],表格的列定义。TColumn 类型包括名字、宽度、排序和格式器属性,方便对各列进行定制配置。
  • search:搜索功能配置,可以实现简单的客户端关键字搜索,或利用 search.server 配置实现服务器端搜索。

Grid.js搜索

  • pagination:分页功能配置,可以实现客户端或服务端的分页功能。

Grid.js分页

总结

Grid.js 作为一个跨框架的前端表格插件,在各个前端框架中都能使用相同的 API 完成表格的定义和渲染,降低了使用不同框架时的学习成本,避免了各种不同依赖所带来的问题。

同时,Grid.js 作为一个功能丰富的插件,提供了主流表格插件的大部分功能;且设计简洁,性能优越,在一些定制化要求不高的表格应用场景中具有很大的优势。

Grid.js 目前正处在积极开发的阶段,版本号更新较快,有兴趣的开发者可以参与开源贡献。而作为一个 TypeScript 项目,Grid.js 代码结构清晰,值得进一步研究学习。

vue前端表格插件_Grid.js - 跨框架的前端表格插件相关推荐

  1. iframe跨域调用js_郑州Web前端基础学习之JS跨域知识梳理

    JS是Web前端开发三要素之一,是郑州Web前端基础学习中非常重要的知识点.JS涉及的知识点多且杂,很多同学反映不知如何下手,事实上,只要你认真记.多练习,就可以慢慢掌握它.今天千锋郑州Web前端培训 ...

  2. 前端 用nginx解决js跨域问题

    前言 公司的一个项目,页面需要给第三方接口发送一个请求,获取第三方接口生成的一个二维码图片,结果 js 跨域获取资源报错:" No 'Access-Control-Allow-Origin' ...

  3. Web前端笔记-使用bootstrap-table.js和bootstrap-table.css使得表格分页

    最终效果如下: 翻页后 首先把bootstrap-table.js和bootstrap-table.css下载下来. 把英文改成中文,如下: 把需要用表格的页面在 </body>前加入此J ...

  4. html5怎么兼容js 插件,Modernizr.js入门指南(HTML5CSS3浏览器兼容插件)

    HTML5 和 CSS3 的快速发展,给我们带来了极大的便利,比如从此再也不用花费大量的时间只是为了设计一个圆角的效果. 但是!我们不能像控制机器一样来控制所有的人都一夜之间升级到现代浏览器,因为那些 ...

  5. ajax小型日期插件,Pikaday.js简约轻量级的日期选择插件 - 资源分享

    Pikaday.js 是一个 JavaScript 日期选择器,它不依赖于任何第三方 JavaScript 库,并且文件大小小于 5K,但是功能却一点不弱,可以进行很多高级定制.并且样式可以根据 CS ...

  6. html制作表格保存为txt文件,可将HTML表格导出为Excel|csv|txt文件的jQuery插件

    TableExport是一款可以将HTML表格导出为Excel xlsx格式.xls格式,以及csv和txt文件的jQuery插件.TableExport插件使用简单,默认使用Bootstrap的CS ...

  7. html导出表格为csv,可将HTML表格导出为Excel|csv|txt文件的jQuery插件

    TableExport是一款可以将HTML表格导出为Excel xlsx格式.xls格式,以及csv和txt文件的jQuery插件.TableExport插件使用简单,默认使用Bootstrap的CS ...

  8. Vue+Flask前后端分离 Vue3跨域配置

    Vue+Flask前后端分离 Vue3跨域配置 前端端口号为8080 后端端口号为5000 问题描述 问题解决 接口路径映射 前端端口号为8080 后端端口号为5000 后端端口API 代码片. @a ...

  9. 点击左右有缝轮播html,超帅轮播插件tabstools.js教程之实现数字+箭头+多栏轮播

    摘要: 前面我们讲了tabstools.js插件可实现多种轮播,如:选项卡轮播.数字轮播.缩略图轮播.卡盘轮播.等等,今天我们再来了解下多栏轮播效果...... 万万没想到!写这篇文章竞是在两个月之后 ...

最新文章

  1. 浅谈Javascript事件模拟
  2. python的类包括_Python的类,复杂吗
  3. 《音乐达人秀:Adobe Audition实战200例》——实例7 定时录制网络音乐节目
  4. 史上最低估自己的天才科学家!预言自己的发现无用,没想到影响全世界,可他却在37岁..........
  5. md5 算法java实现_java实现MD5算法
  6. 2019 The 19th Zhejiang University Programming Contest
  7. 在python程序中嵌入浏览器_用Python中的wxPython实现最基本的浏览器功能
  8. Linux内核多线程——补充(各种平台下的多线程)
  9. c语言实验报告约瑟夫环,C语言约瑟夫环的实现
  10. CAN FD的波特率到底能跑多快?
  11. 常用中文字体的Unicode编码
  12. 程序员如何用优秀免费软件替代盗版软件/流氓软件
  13. userdel: user user is currently used by process 18752解决办法
  14. 华东理工大学计算机考研资料汇总
  15. python输入逗号_python中 逗号的 用法
  16. 对行场、带宽很好解析的一文章
  17. ui设计现状与意义_UI设计存在的意义
  18. Jenkins用户密码重置
  19. Ringbuffer 范例
  20. Linux | Ubuntu | 查看路由 | 修改路由

热门文章

  1. 美多后台管理和项目环境搭建
  2. 爬虫之常见的验证码的种类
  3. 正则表达式匹配分组(|、(ab)、\num、(?P<name>)(?P=name))
  4. YOLOv5实现自定义对象训练与OpenVINO部署全解析
  5. 使用Python+OpenCV+yolov5实现行人目标检测
  6. gcc和g++是什么,有什么区别?
  7. 链表问题4——反转单向链表
  8. MVC Html.ActionLink Area 链接中含区域的页面之间的跳转
  9. 虚拟化云计算平台Proxmox VE
  10. 山石网科发布智能下一代防火墙新版本 应对未知威胁