Handsontable 學習筆記-Methods


Handson: 親自實踐

先給出數據源和基本配置:

 var data =[
       ["A1","B1","C1","D1"],
       ["A2","B2","C2","D2"],
       ["A3","B3","C3","D3"]
     ];
     var objectData = [
       {id: 1, name: 'Ted Right', address: ''},
       {id: 2, name: 'Frank Honest', address: ''},
       {id: 3, name: 'Joan Well', address: ''},
       {id: 4, name: 'Gail Polite', address: ''},
       {id: 5, name: 'Michael Fair', address: ''},
     ];
     var container=document.getElementById('example');
     var ht=new Handsontable(container,{
       data:objectData,
       rowHeaders:true,
       colHeaders:true
       //,disableVisualSelection: true
     });

開始操作表格(一些方法methods)

怎樣獲得表格中某個范圍range的數據?    

alert(ht.getData(0,1));//[A1,B1]
alert(ht.getData(0,2));//[A1,B1,C1]
alert(ht.getData(0,3));//[A1,B1,C1,D1]
alert(ht.getData(0,4));//[A1,B1,C1,D1,] 

alert(ht.getData(1,1));//[A1,B1,A2,B2]
alert(ht.getData(1,2));//[A1,B1,C1,A2,B2,C2]
alert(ht.getData(1,3));//[A1,B1,C1,D1,A2,B2,C2,D2]

alert(ht.getData(2,1));//[A1,B1,A2,B2,A3,B3]

alert(ht.getData(1,1,2,2));//[B2,C2,B3,C3] 這是一個起止區間,類似excel的B2:C3;沒有開始地址的就默認為(0,0),如(0,1)==(0,0,0,1),(2,1)==(0,0,2,1)

怎樣獲得表格中某個單元格cell的數據?

alert('getDataAtCell: ' + ht.getDataAtCell(1,3));// D2

// 若數據源是objectData,屬性名就是id,name,address等。
alert('getDataAtRowProp: ' + ht.getDataAtRowProp(1,'name'));// Frank Honest

 怎樣獲得表格中某一行row的數據?

alert('getDataAtRow: '+ht.getDataAtRow(2));//[3,"Joan Well",""]

 怎樣獲得表格中某一列column的數據?

 alert('getDataAtCol: '+ht.getDataAtCol(1));

 // 類似於getDataAtCol(),只不過將列索引改成了字段屬性名。對object datasource有效。
 alert('getDataAtProp: '+ht.getDataAtProp("name"));

怎樣改變單個或多個單元格的內容?

  ht.setDataAtCell([
      [0,0,'hi:  0,0'],
      [0,2, "hi: 0,2"]
  ]);

  //  根據行號列標(Array data source)或行號列屬性(object datasource)設置單元格的值。
  ht.setDataAtRowProp(1,'name',"wooHAHA");

怎樣在表格中插入行和列?

ht.alter('insert_row',2);// 在第3行上插入一行,不帶行索引表示加入到當前行下方;
// 插入列同理!但是只能用在Array datasource!
ht.alter('insert_col',2);//在第3列前面(左邊)插入一列。

怎樣在表格中刪除行和列?

ht.alter('remove_row');
ht.alter('remove_col'); 

怎樣操作單元格?

alert(ht.getCell(1,1));//獲得單元格對象

ht.getCellMeta(1,1));//獲得單元格的屬性對象
ht.setCellMeta(1,1,"sx","sxz");//設置單元格屬性

// 上面說了如何設置和獲得cell或range的值,下面看看如果選擇它們。
// 獲得和選擇是一樣的嗎?不一樣的概念,get、select
console.log(ht.selectCell(2,2));//預設第三行第三列被選中
alert(ht.getValue());//現在知道getValue怎么回事了吧!當預設有cell被選中時,這個getValue就會顯示選中cell的內容了。

// 好吧,來看看預設選中了什么?
alert(ht.getSelected());//返回坐標,如2,2,2,2

怎么知道表格的行數和列數?

alert('表格行數:'+ht.countRows());
alert('表格列數:'+ht.countCols());

怎么根據列名稱得到列索引,根據列索引得到列名稱?

alert(ht.propToCol('id'));//根據列屬性名獲得列索引,要object datasource才行。但是插入列卻要用array datasource,這么糾結?

alert(ht.colToProp(2));//根據列索引得到該列的屬性名稱,如name,address等。數據源是object才有效。

怎樣獲得行標題和列標題的名稱?

 // 表格配置中有個rowHeaders,一般配置為true,顯示為行號1,2,3,4...。這個也可以自定義的哦,比如 rowHeaders:['第一行','第二行'...],這樣getRowHeader函數就有意義了。
alert(ht.getRowHeader(1));
console.log(ht.getColHeader());//不帶參數返回所有列名稱的array 如["A","B","C"]。

怎么清空表格內容?

ht.clear();


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM