Handsontable数据源

<div id="example" class="hot handsontable htColumnHeaders"></div>

1、数据源为数组

var hot,
    data = [
      ['', 'Kia', 'Nissan', 'Toyota', 'Honda', 'Mazda', 'Ford'],
      ['2012', 10, 11, 12, 13, 15,'','more'],//比第一行多一个元素
      ['2013', 10, 11, 12, 13, 15, 16],
      ['2014', 10, 11, 12, 13, 15, 16],
      [ 11, '2015', 12, 13, 15, 16],
      ['2016', 10, 11, 12, 13, 15, 16]
    ],
    container = document.getElementById('example');

  hot = new Handsontable(container, {
    data: data,
    startRows: 5,
    startCols: 5,
    colHeaders: true,    
  });

由第一行的元素个数决定表有列数,后面的一次填充,多的不会填充,如第二行的'more'


2、数据源为数组,可以隐藏列

var hot,
    hiddenData = [
      ['', 'Kia', 'Nissan', 'Toyota', 'Honda', 'Mazda', 'Ford'],
      ['2012', 10, 11, 12, 13, 15, 16],
      ['2013', 10, 11, 12, 13, 15, 16],
      ['2014', 10, 11, 12, 13, 15, 16],
      ['2015', 10, 11, 12, 13, 15, 16],
      ['2016', 10, 11, 12, 13, 15, 16]
    ],
    container = document.getElementById('example');

  hot = new Handsontable(container, {
    data: hiddenData,
    colHeaders: true,
    minSpareRows: 1,
    columns: [
      {data: 0},
      {data: 2},
      {data: 3},
      {data: 4},
      {data: 5},
      {data: 6}
    ]
  });
  console.log('getData', hot.getData());
  console.log('getSourceData', hot.getSourceData());

下过如图:



但是调用getData()发现里面没有hiddenData 中'Kia'这一列的数据,说明getData()其实只获取能看见的数据,要通过getSourceData()才能看见所有的数据


3、数据源是对象数组 ,没有columns ,

var    hot,
       objectData = [
            {id: 1, address: '86', name: 'Ted Right',a:'nu'},
            {id: 2, name: 'Frank Honest',a:'nu', address: ''},
            {id: 3, name: 'Joan Well', address: ''},
            {id: 4, name: 'Gail Polite', address: ''},
            {id: 5, name: 'Michael Fair', address: ''},
        ],
        container = document.getElementById('example');  
 hot = new Handsontable(container, {
        data: objectData,
        colHeaders: ['第一列','第二列','第三列','第四列'],
    });

根据第一行的内容属性填充数据 后面的向第一行看齐,
如图,第一行有4个属性那么表就有4列,第一列是id,第2列是address,第3列是name,第4列是a,第一行数据依次填充;第二行数据填充时找到数据源中的第二个对象,第一个属性是id,与第一行对应就填充,第二个属性和第一行不对应就自动填充为空,这时继续将第二行的第二个属性和第一行的第三个属性对比(而不是那第二行的第三个属性和第一行的第三个属性对比),发现一致就填充。以此类推。。。
确定有几列后表头一次填充,若colHeaders里面的值不够后面以大写英文字母填充。例如上面的colHeaders为['第一列','第二列','第三列'],那么第四列的表头为'D'。

4、数据源是对象数组,columns是function

var hot,  
      nestedObjects = [
        {id: 1, name: {first: "Ted", last: "Right"}, address: ""},
        {id: 2, address: ""}, // HOT will create missing properties on demand
        {id: 3, name: {first: "Joan", last: "Well"}, address: ""}
      ],
      container = document.getElementById('example');

  hot = new Handsontable(container, {
    data: nestedObjects,
    colHeaders: true,
    columns: function(column) {
      var columnMeta = {};
      if (column === 0) {
        columnMeta.data = 'name.first';
      } else if (column === 1) {
        columnMeta.data = 'id';
      } else if (column === 2) {
        columnMeta.data = 'https://docs.handsontable.com/pro/1.10.2/name.last';
      } else if (column === 3) {
        columnMeta.data = 'address';
      } else {
        columnMeta = null;
      }
      return columnMeta;
    }, 
  });

5、数据源是对象数组,和columns映射(甚至是嵌套的)

   var hot,
        objectData = [
            {id: 1, address: '86',a:'nu',name: {first: 'Ted Right', last:''}},
            {id: 2, a:'nu', name: {first:'Frank Honest', last:''},address: '2'},
            {id: 3, name: 'Joan Well'},
            {id: 4, name: 'Gail Polite', address: '4'},
            {id: 5, name: 'Michael Fair', address: '5'},
        ],
        container = document.getElementById('example');
      
    hot = new Handsontable(container, {
        data: objectData,
        colHeaders: ['第一列','第二列','第三列','第四列','第五列'],
        columns: [
                    {data:'name.first'},
                    {data:'id'},
                    {data: 'address'},
                  ],       
    });

列的内容根据columns对列的定义来填充数据,columns中的 data对应的值对应数据源中对象中的属性。数据源中一个对象为一行数据,对象中的属性的位置和columns中的列位置不同没关系,对象中对应的列的属性没有就为空。


官方文档上还有schema相关的,用的不多就没详看😀

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 223,207评论 6 521
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 95,455评论 3 400
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 170,031评论 0 366
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 60,334评论 1 300
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 69,322评论 6 398
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,895评论 1 314
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,300评论 3 424
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,264评论 0 277
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,784评论 1 321
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,870评论 3 343
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,989评论 1 354
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 36,649评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,331评论 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,814评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,940评论 1 275
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 49,452评论 3 379
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,995评论 2 361

推荐阅读更多精彩内容