vue2.x 整和 Handsontable 内嵌到页面

1.下载  Handsontable ,没发现版本兼容性问题

npm install handsontable

2.代码

<template>
  <div>
    <el-tabs v-model="activeKey" @tab-click="handleTabClick">
      <el-tab-pane label="Tab 1" name="1">
        <div>
          <h1>Handsontable Demo - Tab 1</h1>
          <div style="height: 400px; overflow-x: auto;">
            <div id="hot"></div>
          </div>
        </div>
      </el-tab-pane>
      <el-tab-pane label="Tab 2" name="2">
        <div>
          <h1>Handsontable Demo - Tab 2</h1>
          <div>{{ tab2Data }}</div>
        </div>
      </el-tab-pane>
      <el-tab-pane label="Tab 3" name="3">
        <div>
          <h1>Handsontable Demo - Tab 3</h1>

        </div>
      </el-tab-pane>
    </el-tabs>
  </div>
</template>



<script>
import Handsontable from 'handsontable';
import 'handsontable/dist/handsontable.full.css';
import "handsontable/languages/zh-CN";

export default {
  data() {
    return {
      activeKey: '1',
      tab2Data: 'Content of Tab Pane 2',
      data: [
        ['qwe', 'B1', 'C1'],
        ['A2', 'B2', 'C2'],
        ['A3', 'B3', 'C3'],
      ],
    };
  },
  methods: {
    handleTabClick(tab) {
      this.activeKey = tab.name;
    }
  },
  mounted() {

    const container = document.getElementById('hot');
    const data = [
      ['qwe', 'B1', 'C1'],
      ['A2', 'B2', 'C2'],
      ['A3', 'B3', 'C3'],
    ];
    const hot = new Handsontable(container, {
      colHeaders: [
        "Company name",
        "Country",
        "Name",
        "Sell date",
        "Order ID",
        "In stock",
        "Qty",
        "Progress",
        "Rating"
      ],
      //表格数据
      data:this.data,
      //表格整体宽度
      width: '100%',
      //行表头
      rowHeaders: true,
      //列表头

      //合并单元格
      mergeCells: true,
      //单元格属性
      cell:[],
      //右键菜单
      contextMenu: true,
      //自动拉伸
      stretchH: 'all',
      autoWrapRow: true,
      //下拉菜单
      dropdownMenu: true,
      columnSorting: {
        indicator: true
      },
      autoColumnSize: {
        samplingRatio: 23
      },
      //默认语言
      language: "zh-CN",
      //默认对齐方式
      className: "htCenter htMiddle",
      //许可证  推荐购买官网许可证
      licenseKey: 'ab3e4-1bee8-ed01c-4d94b-08cfe',
      //导出文件插件
      exportFile: true,
      //公式插件
      formulas:true,
      //评论插件
      filters: true, // 启用基本的筛选功能
      comments:true,
      minSpareRows:40,
      minSpareCols:10,
      manualRowResize: true,
      manualColumnResize: true,
      manualColumnMove: true,
      manualRowMove: true,
    });
    },
}
</script>

<style>
#hot {
  width: 100%;
  height: 400px;
  margin: 20px auto;
}

</style>

当前代码的 githup:GitHub - xiaosiwenya/Handsontable_Demo: vue2.6 使用 Handsontable 的模板

官网页面demo:
https://codesandbox.io/s/handsontable-data-grid-v13-0-0-vue-2-demo-hgwyh4?from-embed=&file=/src/components/DataGrid.vue

官网(有api demo):
GitHub - handsontable/handsontable: JavaScript data grid with a spreadsheet look & feel. Works with React, Angular, and Vue. Supported by the Handsontable team ⚡

页面截图:

排序

筛选

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值