handsontable

  • handsontable是目前在前端界最接近excel的插件,可以执行编辑,复制粘贴,插入删除行列,排序等复杂操作。jQueryreactngvue版本,功能强大,是复杂表格的不二之选。本文简单介绍在vue-cli环境下怎么使用。

  • 案例:百度图说官网例子

  • 1.安装与配置

    • npm包安装

    npn install vue-handsontable-official --save
    npn install expose-loader --save-dev//不安装会有错误提示
    • webpack配置(vue-cli),在webpack.base.conf.js中添加一下代码

      {
    test: require.resolve('numbro'),
    loader: 'expose-loader?numbro'
    },
    {
    test: require.resolve('moment'),
    loader: 'expose-loader?moment'
    },
    {
    test: require.resolve('pikaday'),
    loader: 'expose-loader?Pikaday'
    },
    {
    test: require.resolve('zeroclipboard'),
    loader: 'expose-loader?ZeroClipboard'
    }

    2.具体API

    <template>
    <div>
    <div id="example-container" class="wrapper">
    <HotTable :root="root" :settings="hotSettings"></HotTable>
    </div>
    </div> </template>
    <script>
    import moment from 'moment'; //引入handsontable依赖的插件
    import numbro from 'numbro';
    import pikaday from 'pikaday'; //日期插件
    import Zeroclipboard from 'zeroclipboard';
    import Handsontable from 'handsontable';
    import HotTable from 'vue-handsontable-official';
    import Vue from 'vue'; export default {
    data: function () {
    return {
    root: 'test-hot',
    hotSettings: {
    data: [ //数据,可以是数据,对象
    ['20080101', 10, 11, 12, 13,true],
    ['20090101', 20, 11, 14, 13,true],
    ['20010101', 30, 15, 12, 13,true],
    ['20010101', 32, 213, 21, 312,true],
    ['20010201', 32, 213, 21, 312,true],
    ['20010301', 32, 213, 21, 312,true],
    ['20010401', 32, 213, 21, 312,true],
    ['20010501', 32, 213, 21, 312,true],
    ['20010601', 32, 213, 21, 312,true]
    ],
    startRows: 11,//行列范围
    startCols: 6,
    minRows: 5, //最小行列
    minCols: 5,
    maxRows: 20, //最大行列
    maxCols: 20,
    rowHeaders: true,//行表头
    colHeaders: ['时间', 'Kia', 'Nissan', 'Toyota', 'Honda','123'],//自定义列表头or 布尔值
    minSpareCols: 2, //列留白
    minSpareRows: 2,//行留白
    currentRowClassName: 'currentRow', //为选中行添加类名,可以更改样式
    currentColClassName: 'currentCol',//为选中列添加类名
    autoWrapRow: true, //自动换行
    contextMenu: { //自定义右键菜单,可汉化,默认布尔值
    items: {
    "row_above": {
    name:'上方插入一行'
    },
    "row_below": {
    name:'下方插入一行'
    },
    "col_left": {
    name:'左方插入列'
    },
    "col_right": {
    name:'右方插入列'
    },
    "hsep1": "---------", //提供分隔线
    "remove_row": {
    name: '删除行',
    },
    "remove_col": {
    name: '删除列',
    },
    "make_read_only": {
    name: '只读',
    },
    "borders": {
    name: '表格线',
    },
    "commentsAddEdit": {
    name: '添加备注',
    },
    "commentsRemove": {
    name: '取消备注',
    },
    "freeze_column": {
    name: '固定列',
    },
    "unfreeze_column": {
    name: '取消列固定',
    },
    "hsep2": "---------",
    }
    },//右键效果
    fillHandle: true, //选中拖拽复制 possible values: true, false, "horizontal", "vertical"
    fixedColumnsLeft: 0,//固定左边列数
    fixedRowsTop: 0,//固定上边列数
    mergeCells: [ //合并
    {row: 1, col: 1, rowspan: 3, colspan: 3}, //指定合并,从(1,1)开始行3列3合并成一格
    {row: 3, col: 4, rowspan: 2, colspan: 2}
    ],
    columns: [ //添加每一列的数据类型和一些配置
    {
    type: 'date', //时间格式
    dateFormat: 'YYYYMMDD',
    correctFormat: true,
    defaultDate: '19000101'
    },
    {
    type: 'dropdown', //下拉选择
    source: ['BMW', 'Chrysler', 'Nissan', 'Suzuki', 'Toyota', 'Volvo'],
    strict: false //是否严格匹配
    },
    {type: 'numeric'}, //数值
    {type: 'numeric',
    readOnly: true //设置只读
    },
    { type: 'numeric',
    format: '$ 0,0.00'}, //指定的数据格式
    {type: 'checkbox'}, //多选框
    ],
    manualColumnFreeze: true, //手动固定列
    manualColumnMove: true, //手动移动列
    manualRowMove: true, //手动移动行
    manualColumnResize: true,//手工更改列距
    manualRowResize: true,//手动更改行距
    comments: true, //添加注释
    cell: [
    {row: 1, col: 1, comment: {value: 'this is test'}},
    ],
    customBorders:[],//添加边框
    columnSorting: true,//排序
    stretchH: 'all',//根据宽度横向扩展,last:只扩展最后一列,none:默认不扩展 }
    };
    },
    name: 'SampleApp',
    components: {
    HotTable
    }
    }
    </script> <style>
    button{
    margin: 20px 20px;
    }
    .handsontable .currentRow {
    background-color: #E7E8EF;
    } .handsontable .currentCol {
    background-color: #F9F9FB;
    }
    #test-hot {
    width: 800px;
    height: 800px;
    overflow: hidden;
    }
    </style>

    参考地址
    [GitHub地址]:https://github.com/handsontab...
    [handsontable官网]:https://handsontable.com

强大的表格控件handsometable,结合vue的更多相关文章

  1. Atitit  项目界面h5化静态html化计划---vue.js 把ajax获取到的数据 绑定到表格控件 v2 r33.docx

    Atitit  项目界面h5化静态html化计划---vue.js 把ajax获取到的数据 绑定到表格控件 v2 r33.docx 1. 场景:应用在项目列表查询场景下1 1.1. 预计初步掌握vue ...

  2. 葡萄城首席架构师:前端开发与Web表格控件技术解读

    讲师:Issam Elbaytam,葡萄城集团全球首席架构师(Chief Software Architect of GrapeCity Global).曾任 Data Dynamics.Inc 创始 ...

  3. 【新功能前瞻】SpreadJS 纯前端表格控件V12.2:打印增强、拖拽填充等六大特性

    新版本来袭:葡萄城 SpreadJS 纯前端表格控件的全新版本 V12.2 将于8月正式发布! 作为一款备受华为.招商银行.中国平安.苏宁易购等行业专家和前端开发者认可的纯 JavaScript 电子 ...

  4. 如何在web中实现类似excel的表格控件

    Execl功能非常强大,内置的很多函数或公式可以大大提高对数据的加工处理能力.那么在web中有没有类似的控件呢?经过一番搜寻,发现handsontable具备了基本的excel功能支持公式,同时能对数 ...

  5. 最好的Angular2表格控件

    现在市面上有大量的JavaScript数据表格控件,包括开源的第三方的和自产自销的.可以说Wijmo的Flexgrid是目前适应Angular 2的最好的表格控件. Angular 2数据表格基本要求 ...

  6. 12款 JavaScript 表格控件(DataGrid)

    JavaScript 表格控件可以操作大数据集的 HTML表格,提供各种功能,如分页.排序.过滤以及行编辑.在本文中,我们整理了13个最好的 JavaScript 表格插件分享给开发人员,开发者可以很 ...

  7. SNF快速开发平台MVC-各种级联绑定方式,演示样例程序(包含表单和表格控件)

    做了这么多项目,经常会使用到级联.联动的情况. 如:省.市.县.区.一级分类.二级分类.三级分类.仓库.货位. 方式:有表单需要做级联的,还是表格行上需要做级联操作的. 实现:实现方法也有很多种方式. ...

  8. SNF开发平台WinForm-Grid表格控件大全

    我们在开发系统时,会有很多种控件进行展示,甚至有一些为了方便的一些特殊需求. 那么下面就介绍一些我们在表格控件里常用的方便的控件:   1.Grid表格查询条 Grid表格下拉 3.Grid表格弹框选 ...

  9. SNF快速开发平台MVC-EasyUI3.9之-DataGrid表格控件如何增加右键菜单

    如题,我们在项目开发当中会遇到需要,表格控件增加右键菜单的使用. 下面我们就以SNF框架增加右键菜单步骤如下: 1.在加载页面当中增加如下菜单定义 <div id="mm" ...

随机推荐

  1. P2P-BT对端管理协议(附BT协议1.0)

    对端管理 指的是远端peer集合的管理(尽管自身client也能够视为一个peer.但对端管理不包括自身peer) 一个client(client)必须维持与每一个远程peer连接的状态信息,即1V1 ...

  2. java基础:父类与子类之间变量和方法的调用

    1)父类构造函数 java中当调用某个类的构造方法的时候,系统总会调用父类的非静态初始化块进行初始化,这个调用是隐式的,而且父类的静态初始化代码 块总是会被执行,接着调用父类的一个或者多个构造器执行初 ...

  3. spring boot 如何将没有注解的类@Autowired

    等于将类交给spring管理,也就是IOC. 注解@Autowired是自动装配,也就是spring帮你创建对象,当然前提是这个@Autowired的类已经配置成Bean了,spring配置bean文 ...

  4. Verilog HDL设计规范及经验谈(转载)

    1. 规范很重要      工作过的朋友肯定知道,公司里是很强调规范的,特别是对于大的设计(无论软件还是硬件),不按照规范走几乎是不可实现的.逻辑设计也是这样:如果不按规范做的话,过一个月后调试时发现 ...

  5. C# 函数4

    //数据库     public class GF_DA     {         /// <summary>         /// 执行SQL语句 sConnStr 连接字符串,sq ...

  6. Javascript自动打开匹配的超链接

    可以用来点击广告.... 部分代码: function AutoClick() { var DivLink=document.getElementById("divLink"); ...

  7. requirejs源码分析: config中shim

    shim处理的源码: //Merge shim                 if (cfg.shim) {                     eachProp(cfg.shim, funct ...

  8. Django 之基础续

    1.路由系统之动态路由 前言:还记得之前的分页效果,这个如何实现呢?答案就是动态路由. url(r'^detail/(\d+)/$', views.detail), url(r'^detail2/(\ ...

  9. 对vector,list的操作函数

    向量只能接受同一类型的数据:list可以接受不同的数据. 1.添加元素 vector:> b=c(1,2,3) > b=c(b,"four") #直接在后面添加添加 & ...

  10. Python多线程循环

    背景:Python脚本:读取文件中每行,放入列表中:循环读取列表中的每个元素,并做处理操作. 核心:多线程处理单个for循环函数调用 模块:threading 第一部分:   :多线程脚本 (该脚本只 ...