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
    评论
Vue2.x和Vue3.x是Vue.js的两个主要版本。Vue2.x是目前国内市场上最流行的前端应用开发框架之一,而Vue3.x则是最新版本。Vue2.x的官方文档可以在https://v2.cn.vuejs.org找到,而Vue3.x的官方文档可以在https://cn.vuejs.org找到。\[1\] 使用Vue2.x的步骤如下: 1. 下载Vue.jsVuex模块。 2. 创建一个store文件夹,并在其中创建store.js文件,引入VueVuex。 3. 使用Vue.use引入Vuex。 4. 在main.js中引入store,并在实例化Vue对象时加入store对象。 5. 在组件中可以通过this.$store来使用store实例。\[2\] 在Vue2.x中,可以通过注册全局的方式来使用Vuex。在main.js中引入store,并在实例化Vue对象时加入store对象,然后就可以在组件中通过this.$store来使用store实例。\[2\] 在Vue3.x中,可以使用单库模式进行初始化。首先安装Vuex模块,然后在store/index.js中引入VueVuex,并使用Vue.use引入Vuex。在入口文件中引入store,并在实例化Vue对象时加入store对象。然后就可以在组件中通过this.$store来使用store实例。\[3\] #### 引用[.reference_title] - *1* [Vue2.x基础](https://blog.csdn.net/weixin_52218117/article/details/127270468)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Vue系列之---vue2.0 Vuex](https://blog.csdn.net/duanhy_love/article/details/103148874)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值