61 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	API
Luckysheet针对常用的数据操作需求,开放了主要功能的API,开发者可以根据需要进行任意对接开发。
使用注意:
- script全局引入时,所有API均挂载到window.luckysheet对象下面,可以在浏览器控制台打印看到;npm引入时,API也全部挂载在luckysheet对象下
 success回调函数第一个参数为API方法的返回值- 需要新的API请到github Issues中提交,根据点赞数决定是否开放新API
 
单元格操作
getCellValue(row, column [,setting])
- 
参数:
- {Number} [row]: 单元格所在行数;从0开始的整数,0表示第一行
 - {Number} [column]: 单元格所在列数;从0开始的整数,0表示第一列
 - {PlainObject} [setting]: 可选参数
- {String} [type]: 单元格的值类型,可以设置为原始值"v"或者显示值"m";默认值为'v',表示获取单元格的实际值
 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 
 - 
说明:
获取单元格的值。
特殊情况,单元格格式为
yyyy-MM-dd,type为'v'时会强制取'm'显示值 - 
示例:
- 
返回当前工作表第1行第1列单元格的数据的v值
luckysheet.getCellValue(0, 0) - 
返回指定data数据的第2行第2列单元格的原始值。
luckysheet.getCellValue(1, 1, {type:"m"}) 
 - 
 
setCellValue(row, column, value [,setting])
- 
参数:
- {Number} [row]: 单元格所在行数;从0开始的整数,0表示第一行
 - {Number} [column]: 单元格所在列数;从0开始的整数,0表示第一列
 - {Object | String | Number} [value]: 要设置的值;可以为字符串或数字,或为符合Luckysheet单元格格式的对象,参考 单元格属性表
 - {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
说明:
设置某个单元格的值,也可以设置整个单元格对象,用于同时设置多个单元格属性
 - 
示例:
- 设置当前工作表"A1"单元格的值为"abc"
    	
luckysheet.setCellValue(0, 0, 'abc'); 
 - 设置当前工作表"A1"单元格的值为"abc"
    	
 
setCellFormat(row, column, attr, value [,setting])
- 
参数:
- 
{Number} [row]: 单元格所在行数;从0开始的整数,0表示第一行
 - 
{Number} [column]: 单元格所在列数;从0开始的整数,0表示第一列
 - 
{String} [attr]: 属性类型,参考 单元格属性表的属性值
 - 
{String | Number | Object} [value]: 具体的设置值,一个属性会对应多个值,参考 单元格属性表的值示例,特殊情况:如果属性类型
attr是单元格格式ct,则设置值value应提供ct.fa,比如设置A1单元格的格式为百分比格式:luckysheet.setCellFormat(0, 0, "ct", "0.00%") - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
设置某个单元格的属性,如果要设置单元格的值或者同时设置多个单元格属性,推荐使用
setCellValue特殊的设置
- 
边框设置时,attr为
"bd",value为一个key/value对象,需要同时设置边框类型:borderType/边框粗细:style/边框颜色:color/,比如设置A1单元格的边框为所有/红色/细:luckysheet.setCellAttr(0, 0, "bd", {borderType: "border-right",style: "1", color: "#ff0000"})完整可选的设置参数如下:
- 边框类型 
borderType:"border-left" | "border-right" | "border-top" | "border-bottom" | "border-all" | "border-outside" | "border-inside" | "border-horizontal" | "border-vertical" | "border-none", - 边框粗细 
style: 1 Thin | 2 Hair | 3 Dotted | 4 Dashed | 5 DashDot | 6 DashDotDot | 7 Double | 8 Medium | 9 MediumDashed | 10 MediumDashDot | 11 MediumDashDotDot | 12 SlantedDashDot | 13 Thick - 边框颜色 
color: 16进制颜色值 
 - 边框类型 
 
 - 
 - 
示例:
- 设置当前工作表A1单元格文本加粗
luckysheet.setCellFormat(0, 0, "bl", 1) - 设置第二个工作表的B2单元格背景为红色
luckysheet.setCellFormat(1, 1, "bg", "#ff0000", {order:1}) - 设置当前工作表"A1"单元格的值为"abc"
luckysheet.setCellFormat(0, 0, 'v', 'abc'); 
 - 设置当前工作表A1单元格文本加粗
 
find(content [,setting])
- 
参数:
- {String} [content]: 要查找的内容
 - {PlainObject} [setting]: 可选参数
- {Boolean} [isRegularExpression]: 是否正则表达式匹配;默认为 
false - {Boolean} [isWholeWord]: 是否整词匹配;默认为 
false - {Boolean} [isCaseSensitive]: 是否区分大小写匹配;默认为 
false - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Boolean} [isRegularExpression]: 是否正则表达式匹配;默认为 
 
 - 
说明:
查找一个工作表中的指定内容,返回查找到的内容组成的单元格一位数组,数据格式同
celldata。 - 
示例:
- 当前工作表查找
"value"字符串luckysheet.find("value") 
 - 当前工作表查找
 
replace(content, replaceContent [,setting])
- 
参数:
- {String} [content]: 要查找的内容
 - {String} [replaceContent]: 要替换的内容
 - {PlainObject} [setting]: 可选参数
- {Boolean} [isRegularExpression]: 是否正则表达式匹配;默认为 
false - {Boolean} [isWholeWord]: 是否整词匹配;默认为 
false - {Boolean} [isCaseSensitive]: 是否区分大小写匹配;默认为 
false - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Boolean} [isRegularExpression]: 是否正则表达式匹配;默认为 
 
 - 
说明:
查找一个工作表中的指定内容并替换成新的内容,返回替换后的内容组成的单元格一位数组,数据格式同
celldata。 - 
示例:
- 当前工作表查找
"value"字符串并替换为"out"luckysheet.replaces("value", "out) 
 - 当前工作表查找
 
行和列操作
setHorizontalFrozen(isRange [,setting])
- 
参数:
- 
{Boolean} [isRange]: 是否冻结行到选区
isRange可能的值有:"false": 冻结首行"true": 冻结行到选区
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 
isRange为true的时候设置,开启冻结的单元格位置,格式为{ row_focus:0, column_focus:0 },意为当前激活的单元格的行数和列数;默认从当前选区最后的一个选区中取得 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 
 
 - 
 - 
说明:
冻结行操作
特别注意,只有在
isRange设置为true的时候,才需要设置setting中的range,且与一般的range格式不同。 - 
示例:
- 
冻结首行
luckysheet.setHorizontalFrozen(false) - 
冻结到
B5选区luckysheet.setHorizontalFrozen(true, { range: 'B5' }) 
 - 
 
setVerticalFrozen(isRange [,setting])
- 
参数:
- 
{Boolean} [isRange]: 是否冻结列到选区
isRange可能的值有:"false": 冻结首列"true": 冻结列到选区
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 
isRange为true的时候设置,开启冻结的单元格位置,格式为{ row_focus:0, column_focus:0 },意为当前激活的单元格的行数和列数;默认从当前选区最后的一个选区中取得 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 
 
 - 
 - 
说明:
冻结列操作
特别注意,只有在
isRange设置为true的时候,才需要设置setting中的range,且与一般的range格式不同。 - 
示例:
- 
冻结首列
luckysheet.setVerticalFrozen(false) 
 - 
 
setBothFrozen(isRange [,setting])
- 
参数:
- 
{Boolean} [isRange]: 是否冻结行列到选区
isRange可能的值有:"false": 冻结行列"true": 冻结行列到选区
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 
isRange为true的时候设置,开启冻结的单元格位置,格式为{ row_focus:0, column_focus:0 },意为当前激活的单元格的行数和列数;默认从当前选区最后的一个选区中取得 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 
 
 - 
 - 
说明:
冻结行列操作
特别注意,只有在
isRange设置为true的时候,才需要设置setting中的range,且与一般的range格式不同。 - 
示例:
- 
冻结行列
luckysheet.setBothFrozen(false) 
 - 
 
cancelFrozen([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
取消冻结操作
 - 
示例:
- 
取消冻结
luckysheet.cancelFrozen() 
 - 
 
insertRow(row [,setting])
- 
参数:
- 
{Number} [row]: 在第几行插入空白行,从0开始
 - 
{PlainObject} [setting]: 可选参数
- {Number} [number]: 插入的空白行数;默认为 1
 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
在第
row行的位置,插入number行空白行 - 
示例:
- 
在第2行的位置插入1行空白行
luckysheet.insertRow(1) 
 - 
 
insertColumn( column [,setting])
- 
参数:
- 
{Number} [column]: 在第几列插入空白列
 - 
{PlainObject} [setting]: 可选参数
- {Number} [number]: 插入的空白列数;默认为 1
 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
在第
column列的位置,插入number列空白列 - 
示例:
- 
在第1列的位置插入3行空白行
luckysheet.insertRow(0, { number: 3 }) 
 - 
 
deleteRow(rowStart, rowEnd [,setting])
- 
参数:
- 
{Number} [rowStart]: 要删除的起始行
 - 
{Number} [rowEnd]: 要删除的结束行
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
删除指定的行
特别提醒,删除行之后,行的序号并不会变化,下面的行会补充到上面,注意观察数据是否被正确删除即可。
 - 
示例:
- 
删除2-4行
luckysheet.deleteRow(1, 3) 
 - 
 
deleteColumn(columnStart, columnEnd [,setting])
- 
参数:
- 
{Number} [columnStart]: 要删除的起始列
 - 
{Number} [columnEnd]: 要删除的结束列
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
删除指定的列
特别提醒,删除列之后,列的序号并不会变化,右边的列会补充到左边,注意观察数据是否被正确删除即可。
 - 
示例:
- 
删除2-4列
luckysheet.deleteColumn(1, 3) 
 - 
 
hideRow(rowStart, rowEnd [,setting])
- 
参数:
- 
{Number} [rowStart]: 要隐藏的起始行
 - 
{Number} [rowEnd]: 要隐藏的结束行
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
隐藏指定的行
特别提醒,隐藏行之后,行的序号会变化。
 - 
示例:
- 
隐藏2-4行
luckysheet.hideRow(1, 3) 
 - 
 
hideColumn(columnStart, columnEnd [,setting])(TODO)
- 
参数:
- 
{Number} [columnStart]: 要隐藏的起始列
 - 
{Number} [columnEnd]: 要隐藏的结束列
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
隐藏指定的列
特别提醒,隐藏列之后,列的序号会变化。
 - 
示例:
- 
隐藏2-4列
luckysheet.hideColumn(1, 3) 
 - 
 
showRow(rowStart, rowEnd [,setting])
- 
参数:
- 
{Number} [rowStart]: 要显示的起始行
 - 
{Number} [rowEnd]: 要显示的结束行
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
显示指定的行
 - 
示例:
- 
显示2-4行
luckysheet.showRow(1, 3) 
 - 
 
showColumn(columnStart, columnEnd [,setting])(TODO)
- 
参数:
- 
{Number} [columnStart]: 要显示的起始列
 - 
{Number} [columnEnd]: 要显示的结束列
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
显示指定的列
 - 
示例:
- 
显示2-4列
luckysheet.showColumn(1, 3) 
 - 
 
选区操作
getRange([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
返回当前选区对象的数组,可能存在多个选区。每个选区的格式为row/column信息组成的对象
{row:[0,1],column:[0,1]} - 
示例:
- 
当前选区为"A1:B2"和"B4:C5",执行
luckysheet.getRange()则返回结果为:
[ { "row": [0,1], "column": [0,1] }, { "row": [3,4], "column": [1,2] } ] 
 - 
 
getRangeValue([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
返回指定工作表指定范围的单元格二维数组数据,每个单元格为一个对象。
 - 
示例:
- 
当前选区为"A1:B2",执行
luckysheet.getRangeValue()则返回结果为:
[ [ { "v": "vaule1", "ct": { "fa": "General", "t": "g" }, "m": "vaule1", "bg": "rgba(255,255,255)", "bl": 0, "it": 0, "ff": 1, "fs": 11, "fc": "rgb(51, 51, 51)", "ht": 1, "vt": 0 }, { "v": "value3", "ct": { "fa": "General", "t": "g" }, "m": "value3", "bg": "rgba(255,255,255)", "bl": 0, "it": 0, "ff": 1, "fs": 11, "fc": "rgb(51, 51, 51)", "ht": 1, "vt": 0 } ], [ { "v": "vaule2", "ct": { "fa": "General", "t": "g" }, "m": "vaule2", "bg": "rgba(255,255,255)", "bl": 0, "it": 0, "ff": 1, "fs": 11, "fc": "rgb(51, 51, 51)", "ht": 1, "vt": 0 }, { "v": "value4", "ct": { "fa": "General", "t": "g" }, "m": "value4", "bg": "rgba(255,255,255)", "bl": 0, "it": 0, "ff": 1, "fs": 11, "fc": "rgb(51, 51, 51)", "ht": 1, "vt": 0 } ] ] 
 - 
 
getRangeHtml([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
复制指定工作表指定单元格区域的数据,返回包含
<table>html格式的数据,可用于粘贴到excel中保持单元格样式。特别注意,如果复制多个选区,这几个选区必须有相同的行或者相同的列才能复制,复制出的结果也会自动合并成衔接的数组,比如,多选
"C18:C20"/"E18:E20"/"G18:H20"是允许的,但是多选"C18:C20"/"E18:E21"是不允许的 - 
示例:
- 
当前选区为"A1:B2",执行
luckysheet.getRangeHtml()则返回结果为:
<table data-type="luckysheet_copy_action_table"> <colgroup width="72px"> </colgroup> <colgroup width="72px"> </colgroup> <tr> <td style="height:19px;"> value1 </td> <td style=""> value3 </td> </tr> <tr> <td style="height:19px;"> value2 </td> <td style=""> value4 </td> </tr> </table> 
 - 
 
getRangeJson(title [,setting])
- 
参数:
- 
{Boolean} [title]: 是否首行为标题
title可能的值有:"true": 首行为标题"false": 首行不为标题
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
复制指定工作表指定单元格区域的数据,返回
json格式的数据 - 
示例:
- 
当前选区为"A1:B2",首行为标题取得json
luckysheet.getRangeJson(true)则返回结果为:
[ { "A": "value1", "B": "value3" }, { "A": "value2", "B": "value4" } ] - 
当前选区为"A1:B2",首行不为标题取得json
luckysheet.getRangeJson(false)则返回结果为:
[ { "value1": "value2", "value3": "value4" } ] 
 - 
 
getRangeArray(dimensional [,setting])
- 
参数:
- 
{String} [dimensional]: 数组维度
dimensional可能的值有:"oneDimensional": 一维数组"twoDimensional": 二维数组"custom": 自定义行列数的二维数组
 - 
{PlainObject} [setting]: 可选参数
- {Number} [row]: 
dimensional为custom的时候设置,多维数组的行数 - {Number} [column]: 
dimensional为custom的时候设置,多维数组的列数 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Number} [row]: 
 
 - 
 - 
说明:
复制指定工作表指定单元格区域的数据,返回一维、二维或者自定义行列数的二维数组的数据。
特别注意,只有在
dimensional设置为custom的时候,才需要设置setting中的row和column - 
示例:
- 
当前选区为"A1:B2",一维数组
luckysheet.getRangeArray('oneDimensional')则返回结果为:
["value1","value3","value2","value4"] - 
当前选区为"A1:B2",二维数组
luckysheet.getRangeArray('twoDimensional')则返回结果为:
[ [ "value1", "value3" ], [ "value2", "value4" ] ] - 
当前选区为"A1:C5",由 'value1'到'value15'的值组成,得到3 行2列的二维数组数据
luckysheet.getRangeArray('custom', { row: 3, column: 2 })则返回结果为:
[ [ { "m": "value1", "ct": { "fa": "General", "t": "g" }, "v": "value1" }, { "ct": { "fa": "General", "t": "g" }, "v": "value6", "m": "value6" } ], [ { "ct": { "fa": "General", "t": "g" }, "v": "value11", "m": "value11" }, { "m": "value2", "ct": { "fa": "General", "t": "g" }, "v": "value2" } ], [ { "ct": { "fa": "General", "t": "g" }, "v": "value7", "m": "value7" }, { "ct": { "fa": "General", "t": "g" }, "v": "value12", "m": "value12" } ] ] 
 - 
 
getRangeDiagonal(type [,setting])
- 
参数:
- 
{String} [type]: 对角线还是对角线偏移
type可能的值有:"normal": 对角线"anti": 反对角线"offset": 对角线偏移
 - 
{PlainObject} [setting]: 可选参数
- {Number} [column]: 
type为offset的时候设置,对角偏移的列数 
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Number} [column]: 
 
 - 
 - 
说明:
复制指定工作表指定单元格区域的数据,返回对角线或者对角线偏移
column列后的数据。特别注意,只有在
type设置为offset的时候,才需要设置setting中的column。 - 
示例:
- 
当前选区为"A1:B2",对角线
luckysheet.getRangeDiagonal('normal')则返回结果为:
[ { "m": "value1", "ct": { "fa": "General", "t": "g" }, "v": "value1" }, { "m": "value4", "ct": { "fa": "General", "t": "g" }, "v": "value4" } ] - 
当前选区为"A1:B2",反对角线
luckysheet.getRangeDiagonal('anti')则返回结果为:
[ { "m": "value3", "ct": { "fa": "General", "t": "g" }, "v": "value3" }, { "m": "value2", "ct": { "fa": "General", "t": "g" }, "v": "value2" } ] - 
当前选区为"A1:B2",对角线偏移1列
luckysheet.getRangeDiagonal('offset', { column: 1 })则返回结果为:
[ { "m": "value3", "ct": { "fa": "General", "t": "g" }, "v": "value3" } ] 
 - 
 
getRangeBoolean([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
复制指定工作表指定单元格区域的数据,返回布尔值的数据
 - 
示例:
- 
当前选区为"A1:B2"
luckysheet.getRangeBoolean()则返回结果为:
[ [ false, false ], [ false, false ] ] 
 - 
 
setRangeShow(range [,setting])
- 
参数:
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {PlainObject} [setting]: 可选参数
- {Boolean} [show]: 是否显示高亮选中效果;默认值为 
true - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Boolean} [show]: 是否显示高亮选中效果;默认值为 
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 - 
说明:
指定工作表选中一个或多个选区为选中状态并选择是否高亮,支持多种格式设置。
特别提醒,Luckysheet中涉及到的选区范围设置都可以参考这个设置
 - 
示例:
- 
设定当前工作表选区范围
A1:B2:luckysheet.setRangeShow("A1:B2") - 
设定选区范围
A1:B2:luckysheet.setRangeShow(["A1:B2"]) - 
设定选区范围
A1:B2:luckysheet.setRangeShow({row:[0,1],column:[0,1]}) - 
设定选区范围
A1:B2:luckysheet.setRangeShow([{row:[0,1],column:[0,1]}]) - 
设定选区范围
A1:B2和C3:D4:luckysheet.setRangeShow(["A1:B2","C3:D4"]) - 
设定选区范围
A1:B2和D3:luckysheet.setRangeShow([{row:[0,1],column:[0,1]},{row:[2,2],column:[3,3]}]) 
 - 
 
setRangeValue(data [,setting])
- 
参数:
- {Array} [data]: 要赋值的单元格二维数组数据,每个单元格的值,可以为字符串或数字,或为符合Luckysheet格式的对象,参考 单元格属性表
 - {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
说明:
将一个单元格数组数据赋值到指定的区域,数据格式同
getRangeValue方法取到的数据。 - 
示例:
- 
赋值到当前选区
const data = [ [ { "m": "value1", "ct": { "fa": "General", "t": "g" }, "v": "value1" }, { "m": "value3", "ct": { "fa": "General", "t": "g" }, "v": "value3" } ], [ { "m": "value2", "ct": { "fa": "General", "t": "g" }, "v": "value2" }, { "m": "value4", "ct": { "fa": "General", "t": "g" }, "v": "value4" } ] ] luckysheet.setRangeValue(data)``
 
 - 
 
setRangeFormat(attr, value [,setting])
- 
参数:
- 
{String} [attr]: 属性类型, 参考 单元格属性表的属性值
 - 
{String | Number | Object} [value]: 具体的设置值,一个属性会对应多个值,参考 单元格属性表的值示例,特殊情况:如果属性类型
attr是单元格格式ct,则设置值value应提供ct.fa,比如设置"A1:B2"单元格的格式为百分比格式:luckysheet.setRangeFormat("ct", "0.00%", {range:"A1:B2"}) - 
{PlainObject} [setting]: 可选参数
- {Object | String} [range]: 设置参数的目标选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Object | String} [range]: 设置参数的目标选区范围,支持选区的格式为
 
 - 
 - 
说明:
设置指定范围的单元格格式,一般用作处理格式,赋值操作推荐使用
setRangeValue方法- 
边框设置时,attr为
"bd",value为一个key/value对象,需要同时设置边框类型:borderType/边框粗细:style/边框颜色:color/,比如设置"A1:B2"单元格的边框为所有/红色/细:luckysheet.setRangeFormat("bd", {borderType: "border-right",style: "1", color: "#ff0000"}, {range:["A1:B2"]})完整可选的设置参数如下:
- 边框类型 
borderType:"border-left" | "border-right" | "border-top" | "border-bottom" | "border-all" | "border-outside" | "border-inside" | "border-horizontal" | "border-vertical" | "border-none", - 边框粗细 
style: 1 Thin | 2 Hair | 3 Dotted | 4 Dashed | 5 DashDot | 6 DashDotDot | 7 Double | 8 Medium | 9 MediumDashed | 10 MediumDashDot | 11 MediumDashDotDot | 12 SlantedDashDot | 13 Thick - 边框颜色 
color: 16进制颜色值 
 - 边框类型 
 
 - 
 - 
示例:
- 
设置当前工作表
"A1:B2"范围的单元格文本加粗luckysheet.setRangeFormat("bl", 1, {range:"A1:B2"}) - 
设置第二个工作表的
"B2"和"C4:D5"范围的单元格背景为红色luckysheet.setRangeFormat("bg", "#ff0000", {range:["B2","C4:D5"], order:1}) 
 - 
 
setRangeFilter(type [,setting])
- 
参数:
- 
{String} [type]: 打开还是关闭筛选功能
type可能的值有:"open": 打开筛选功能,返回当前筛选的范围对象"close": 关闭筛选功能,返回关闭前筛选的范围对象
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围开启或关闭筛选功能
 - 
示例:
- 打开第二个工作表"A1:B2"范围的筛选功能
luckysheet.setRangeFilter("open",{range:"A1:B2",order:1}) 
 - 打开第二个工作表"A1:B2"范围的筛选功能
 
setRangeMerge(type [,setting])
- 
参数:
- 
{String} [type]: 合并单元格类型
type可能的值有:"all": 全部合并,区域内所有单元格合并成一个大的单元格"horizontal": 水平合并,区域内在同一行的单元格合并成一个单元格"vertical": 垂直合并,区域内在同一列的单元格合并成一个单元格
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围设定合并单元格
 - 
示例:
- 
当前选区 'A1:B2' 设置为合并单元格,类型为全部合并
luckysheet.setRangeMerge("all")得到 'A1:B1' 的数据为:[ [ { "m": "value1", "ct": { "fa": "General", "t": "g" }, "v": "value1", "mc": { "r": 0, "c": 0, "rs": 2, "cs": 2 } }, { "mc": { "r": 0, "c": 0 } } ], [ { "mc": { "r": 0, "c": 0 } }, { "mc": { "r": 0, "c": 0 } } ] ] 
 - 
 
cancelRangeMerge( [setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
为指定索引的工作表,选定的范围取消合并单元格
 - 
示例:
- 
当前选区 'A1:B2' 已为合并单元格,现在要取消合并
luckysheet.cancelRangeMerge() 
 - 
 
setRangeSort(type [,setting])
- 
参数:
- 
{String} [type]: 排序类型
type可能的值有:"asc": 升序"des": 降序
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围开启排序功能,返回选定范围排序后的数据。
 - 
示例:
- 设置当前工作表当前选区为升序
luckysheet.setRangeSort("asc") 
 - 设置当前工作表当前选区为升序
 
setRangeSortMulti(title, sort [,setting])
- 
参数:
- 
{Boolean} [title]: 数据是否具有标题行
 - 
{Array} [sort]: 列设置,设置需要排序的列索引和排序方式,格式如:
[{ i:0,sort:'asc' },{ i:1,sort:'des' }] - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围开启多列自定义排序功能,返回选定范围排序后的数据。
 - 
示例:
- 设置当前工作表当前选区为自定义排序,数据具有标题行,且按第一列升序第二列降序的规则进行排序
luckysheet.setRangeSortMulti(true,{sort:[{ i:0,sort:'asc' },{ i:1,sort:'des' }]}) 
 - 设置当前工作表当前选区为自定义排序,数据具有标题行,且按第一列升序第二列降序的规则进行排序
 
setRangeConditionalFormatDefault(conditionName, conditionValue [,setting])
- 
参数:
- 
{String} [conditionName]: 条件格式规则类型
conditionName可能的值有:"greaterThan": 大于"lessThan": 小于"betweenness": 介于"equal": 等于"textContains": 文本包含"occurrenceDate": 发生日期"duplicateValue": 重复值"top": 前 N 项(可以在conditionValue中设置其他值)"topPercent": 前 N%(可以在conditionValue中设置其他值)"last": 后 N 项(可以在conditionValue中设置其他值)"lastPercent": 后 N%(可以在conditionValue中设置其他值)"AboveAverage": 高于平均值"SubAverage": 低于平均值
 - 
{Object} [conditionValue]: 可以设置条件单元格或者条件值 取值规则
{ type: 'value', content: [2] }或者 ```js { type: 'range', content: ['A1'] } - 
{PlainObject} [setting]: 可选参数
- 
{Object | Array} [format]: 颜色设置
type为default时,应设置文本颜色和单元格颜色;默认值为{ "textColor": "#000000", "cellColor": "#ff0000" }
 - 
{Boolean} [isEdit]: 是否在修改条件格式规则;默认为
false - 
{Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - 
{Number} [order]: 工作表索引;默认值为当前工作表索引
 - 
{Function} [success]: 操作结束的回调函数
 
 - 
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围开启条件格式,根据设置的条件格式规则突出显示部分单元格,返回开启条件格式后的数据。
 - 
示例:
- 
突出显示内容大于数字2的单元格
luckysheet.setRangeConditionalFormatDefault("greaterThan",{ type: 'value', content: [2] }) - 
突出显示内容小于单元格A1内容的单元格
luckysheet.setRangeConditionalFormatDefault("lessThan",{ type: 'range', content: ['A1'] }) - 
突出显示内容介于2和10之间的单元格
luckysheet.setRangeConditionalFormatDefault("betweenness",{ type: 'value', content: [2,10] }) - 
突出显示内容等于单元格A1内容的单元格
luckysheet.setRangeConditionalFormatDefault("equal",{ type: 'range', content: ['A1'] }) - 
突出显示内容包含单元格A1内容的单元格
luckysheet.setRangeConditionalFormatDefault("textContains",{ type: 'range', content: ['A1'] }) - 
突出显示日期在
2020/09/24 - 2020/10/15之间的单元格luckysheet.setRangeConditionalFormatDefault("occurrenceDate",{ type: 'value', content: ['2020/09/24 - 2020/10/15'] }) - 
突出显示重复值的单元格,content为0
luckysheet.setRangeConditionalFormatDefault("duplicateValue",{ type: 'value', content: [0] }) - 
突出显示唯一值的单元格,content为1
luckysheet.setRangeConditionalFormatDefault("duplicateValue",{ type: 'value', content: [1] }) - 
突出显示排名前20名的单元格
luckysheet.setRangeConditionalFormatDefault("top",{ type: 'value', content: [20] }) - 
突出显示排名前30%的单元格
luckysheet.setRangeConditionalFormatDefault("topPercent",{ type: 'value', content: [30] }) - 
突出显示排名后15名的单元格
luckysheet.setRangeConditionalFormatDefault("last",{ type: 'value', content: [15] }) - 
突出显示排名后15%的单元格
luckysheet.setRangeConditionalFormatDefault("lastPercent",{ type: 'value', content: [15] }) - 
突出显示高于平均值的单元格
luckysheet.setRangeConditionalFormatDefault("AboveAverage",{ type: 'value', content: ['AboveAverage'] }) - 
突出显示低于平均值的单元格
luckysheet.setRangeConditionalFormatDefault("SubAverage",{ type: 'value', content: ['SubAverage'] }) 
 - 
 
setRangeConditionalFormat(type [,setting])
- 
参数:
- 
{String} [type]: 条件格式规则类型
type可能的值有:"dataBar": 数据条"icons": 图标集"colorGradation": 色阶
 - 
{PlainObject} [setting]: 可选参数
- 
{Object | Array} [format]: 颜色设置
- 
type为dataBar时,应设置渐变色;默认值为蓝-白渐变["#638ec6", "#ffffff"]推荐的快捷取值:
["#638ec6", "#ffffff"], //蓝-白渐变 数据条 ["#63c384", "#ffffff"], //绿-白渐变 数据条 ["#ff555a", "#ffffff"], //红-白渐变 数据条 ["#ffb628", "#ffffff"], //橙-白渐变 数据条 ["#008aef", "#ffffff"], //浅蓝-白渐变 数据条 ["#d6007b", "#ffffff"], //紫-白渐变 数据条 ["#638ec6"], //蓝色 数据条 ["#63c384"], //绿色 数据条 ["#ff555a"], //红色 数据条 ["#ffb628"], //橙色 数据条 ["#008aef"], //浅蓝色 数据条 ["#d6007b"] //紫色 数据条 - 
type为icons时,应设置图标类型;默认值为"threeWayArrowColor":三向箭头彩色,可取值为:
threeWayArrowMultiColor:三向箭头(彩色),threeTriangles:3个三角形,fourWayArrowMultiColor:四向箭头(彩色),fiveWayArrowMultiColor:五向箭头(彩色),threeWayArrowGrayColor:三向箭头(灰色),fourWayArrowGrayColor:四向箭头(灰色),fiveWayArrowGrayColor:五向箭头(灰色),threeColorTrafficLightRimless:三色交通灯(无边框),threeSigns:三标志,greenRedBlackGradient:绿-红-黑渐变,threeColorTrafficLightBordered:三色交通灯(有边框),fourColorTrafficLight:四色交通灯,threeSymbolsCircled:三个符号(有圆圈),tricolorFlag:三色旗,threeSymbolsnoCircle:三个符号(无圆圈),threeStars:3个星形,fiveQuadrantDiagram:五象限图,fiveBoxes:5个框,grade4:四等级,grade5:五等级, - 
type为colorGradation时,应设置色阶颜色值;默认值为绿-黄-红色阶["rgb(99, 190, 123)", "rgb(255, 235, 132)", "rgb(248, 105, 107)"]推荐的快捷取值:
["rgb(99, 190, 123)", "rgb(255, 235, 132)", "rgb(248, 105, 107)"], //绿-黄-红色阶 ["rgb(248, 105, 107)", "rgb(255, 235, 132)", "rgb(99, 190, 123)"], //红-黄-绿色阶 ["rgb(99, 190, 123)", "rgb(252, 252, 255)", "rgb(248, 105, 107)"], //绿-白-红色阶 ["rgb(248, 105, 107)", "rgb(252, 252, 255)", "rgb(99, 190, 123)"], //红-白-绿色阶 ["rgb(90, 138, 198)", "rgb(252, 252, 255)", "rgb(248, 105, 107)"], //蓝-白-红色阶 ["rgb(248, 105, 107)", "rgb(252, 252, 255)", "rgb(90, 138, 198)"], //红-白-蓝色阶 ["rgb(252, 252, 255)", "rgb(248, 105, 107)"], //白-红色阶 ["rgb(248, 105, 107)", "rgb(252, 252, 255)"], //红-白色阶 ["rgb(99, 190, 123)", "rgb(252, 252, 255)"], //绿-白色阶 ["rgb(252, 252, 255)", "rgb(99, 190, 123)"], //白-绿色阶 ["rgb(99, 190, 123)", "rgb(255, 235, 132)"], //绿-黄色阶 ["rgb(255, 235, 132)", "rgb(99, 190, 123)"] //黄-绿色阶 
 - 
 - 
{Boolean} [isEdit]: 是否在修改条件格式规则;默认为
false - 
{Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - 
{Number} [order]: 工作表索引;默认值为当前工作表索引
 - 
{Function} [success]: 操作结束的回调函数
 
 - 
 
 - 
 - 
说明:
为指定索引的工作表,选定的范围开启条件格式,返回开启条件格式后的数据。
 - 
示例:
- 当前选区范围开启条件格式,显示渐变色
luckysheet.setRangeConditionalFormat("dataBar", { format: ["#63c384", "#ffffff"] }) 
 - 当前选区范围开启条件格式,显示渐变色
 
deleteRangeConditionalFormat(itemIndex [,setting])
- 
参数:
- 
{Number} [itemIndex]: 条件格式规则索引
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
为指定索引的工作表,删除条件格式规则,返回被删除的条件格式规则。
 - 
示例:
- 删除第三个条件格式规则
luckysheet.deleteRangeConditionalFormat(2) 
 - 删除第三个条件格式规则
 
clearRange([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 要清除的选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 要清除的选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
清除指定工作表指定单元格区域的内容,返回清除掉的数据,不同于删除选区的功能,不需要设定单元格移动情况
 - 
示例:
- 清空当前选区内容
luckysheet.clearRange() 
 - 清空当前选区内容
 
deleteRange(move [,setting])
- 
参数:
- 
{String} [move]: 删除后,右侧还是下方的单元格移动
move可能的值有:"left": 右侧单元格左移"up": 下方单元格上移
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 要删除的选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},允许多个选区组成的数组;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 要删除的选区范围,支持选区的格式为
 
 - 
 - 
说明:
删除指定工作表指定单元格区域,返回删除掉的数据,同时,指定是右侧单元格左移还是下方单元格上移
 - 
示例:
- 删除当前选区并且在删除后,右侧单元格左移
luckysheet.deleteRange('left') 
 - 删除当前选区并且在删除后,右侧单元格左移
 
insertRange(move [,setting])
- 
参数:
- 
{String} [move]: 活动单元格右移或者下移
move可能的值有:"right": 活动单元格右移"bottom": 活动单元格下移
 - 
{PlainObject} [setting]: 可选参数
- 
{Array} [data]: 赋值到range区域的单元格二维数组数据,单元格对象格式参考;默认值为空数组,即插入空白的区域
 - 
{Array | Object | String} [range]: 要插入的位置,选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},默认为当前选区当未设置data数据时,允许多个选区组成的数组,插入的空白区域即为这些选区的区域,
当设置了data数据,只能为单个选区,并且会把data数据插入到当前选区的第一个单元格位置
 - 
{Number} [order]: 工作表索引;默认值为当前工作表索引
 - 
{Function} [success]: 操作结束的回调函数
 
 - 
 
 - 
 - 
说明:
在指定工作表指定单元格区域,赋值单元格数据,或者新建一块空白区域,返回data数据,同时,指定活动单元格右移或者下移
 - 
示例:
- 当前选区位置插入空白单元格,并且插入后当前选区单元格右移
luckysheet.insertRange('right') 
 - 当前选区位置插入空白单元格,并且插入后当前选区单元格右移
 
matrixOperation(type [,setting])
- 
参数:
- 
{String} [type]: 矩阵操作的类型
type可能的值有:"flipUpDown": 上下翻转"flipLeftRight": 左右翻转"flipClockwise": 顺时针旋转"flipCounterClockwise": 逆时针旋转"Transpose": 转置"DeleteZeroByRow": 按行删除两端0值"DeleteZeroByColumn": 按列删除两端0值"removeDuplicateByRow": 按行删除重复值"removeDuplicateByColumn": 按列删除重复值"newMatrix": 生产新矩阵
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
指定工作表指定单元格区域的数据进行矩阵操作,返回操作成功后的结果数据
 - 
示例:
- 
当前选区上下翻转
luckysheet.matrixOperation('flipUpDown')原来的选区复制为二维数组:
[["value1","value3"],["value2","value4"]]上下翻转后选区复制为二维数组:
[["value2","value4"],["value1","value3"]] 
 - 
 
matrixCalculation(type, number [,setting])
- 
参数:
- 
{String} [type]: 计算方式
type可能的值有:"plus": 加"minus": 减"multiply": 乘"divided": 除"power": 次方"root": 次方根"log": log
 - 
{Number} [number]: 计算数值,如: 2
 - 
{PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - 
 - 
说明:
指定工作表指定单元格区域的数据进行矩阵计算,返回计算成功后的结果数据
 - 
示例:
- 
当前选区所有单元格值加2
luckysheet.matrixCalculation('plus', 2)原来的选区复制为二维数组:
[[1,2],[3,4]]加2后选区复制为二维数组:
[[3,4],[5,6]] 
 - 
 
工作表操作
getAllSheets()
- 
说明:
返回所有工作表配置,格式同工作表配置,得到的结果可用于表格初始化时作为
options.data使用。所以此API适用于,手动操作配置完一个表格后,将所有工作表信息取出来自行保存,再用于其他地方的表格创建。
 - 
示例:
- 取得第一个工作表的所有基本信息
luckysheet.getAllSheets()[0] 
 - 取得第一个工作表的所有基本信息
 
getLuckysheetfile()
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
返回所有表格数据结构的一维数组
luckysheetfile,不同于getAllSheets方法,此方法得到的工作表参数会包含很多内部使用变量,最明显的区别是表格数据操作会维护luckysheetfile[i].data,而初始化数据采用的是options.data[i].celldata,所以luckysheetfile可用于调试使用,但是不适用初始化表格。 - 
示例:
- 取得第一个工作表的所有调试信息
luckysheet.getLuckysheetfile()[0] 
 - 取得第一个工作表的所有调试信息
 
getSheetData([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
快捷返回指定工作表的数据,同
luckysheetfile[i].data 
getConfig([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
快捷返回指定工作表的config配置,同
luckysheetfile[i].config 
setConfig([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
快捷设置当前表格config配置
 
setSheetAdd([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Object} [sheetObject]: 新增的工作表的数据;默认值为空对象
 - {Number} [order]: 新增的工作表索引;默认值为最后一个索引位置
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
新增一个sheet,返回新增的工作表对象,
setting中可选设置数据为sheetObject,不传sheetObject则会新增一个空白的工作表 - 
示例:
- 在最后一个工作表索引位置新增一个空白的工作表
luckysheet.setSheetAdd() 
 - 在最后一个工作表索引位置新增一个空白的工作表
 
setSheetDelete([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
删除指定索引的工作表,返回已删除的工作表对象
 - 
示例:
- 删除当前工作表
luckysheet.setSheetDelete() 
 - 删除当前工作表
 
setSheetCopy([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [targetOrder]: 新复制的工作表目标索引位置;默认值为当前工作表索引的下一个索引位置(递增)
 - {Number} [order]: 被复制的工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
复制指定索引的工作表到指定索引位置,在
setting中可选设置指定索引位置targetOrder,返回新复制的工作表对象 - 
示例:
- 复制当前工作表到下一个索引位置
luckysheet.setSheetCopy() 
 - 复制当前工作表到下一个索引位置
 
setSheetHide([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 被隐藏的工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
隐藏指定索引的工作表,返回被隐藏的工作表对象
 - 
示例:
- 隐藏当前工作表
luckysheet.setSheetHide(true) - 隐藏第三个工作表
luckysheet.setSheetHide({order:2}) 
 - 隐藏当前工作表
 
setSheetShow([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Number} [order]: 被取消隐藏的工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
取消隐藏指定索引的工作表,返回被取消隐藏的工作表对象
 - 
示例:
- 取消隐藏第三个工作表
luckysheet.setSheetShow({order:2}) 
 - 取消隐藏第三个工作表
 
setSheetActive(order [,setting])
- 
参数:
- {Number} [order]: 要激活的工作表索引
 - {PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
说明:
设置指定索引的工作表为当前工作表(激活态),即切换到指定的工作表,返回被激活的工作表对象
 - 
示例:
- 切换到第二个工作表
luckysheet.setSheetActive(1) 
 - 切换到第二个工作表
 
setSheetName(name [,setting])
- 
参数:
- {String} [name]: 新的工作表名称
 - {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
说明:
修改工作表名称
 - 
示例:
- 修改当前工作表名称为"CellSheet"
luckysheet.setSheetName("CellSheet") 
 - 修改当前工作表名称为"CellSheet"
 
setSheetColor(color [,setting])
- 
参数:
- {String} [color]: 工作表颜色
 - {PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
说明:
设置工作表名称处的颜色
 - 
示例:
- 修改当前工作表名称处的颜色为红色
luckysheet.setSheetColor("#ff0000") 
 - 修改当前工作表名称处的颜色为红色
 
setSheetMove(type [,setting])
- 
参数:
- 
{String | Number} [type]: 工作表移动方向或者移动的目标索引,
type可能的值有:"left": 向左"right": 向右1/2/3/...: 指定索引
 - 
{PlainObject} [setting]: 可选参数
- {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
指定工作表向左边或右边移动一个位置,或者指定索引,返回指定的工作表对象
 - 
示例:
- 当前工作表向左移动一个位置
luckysheet.setSheetMove("left") - 第二个工作表移动到第四个工作表的索引位置
luckysheet.setSheetMove(3,{order:1}) 
 - 当前工作表向左移动一个位置
 
工作簿操作
create(options [,setting])
- 
参数:
- {Object} [options]:表格的所有配置信息
 - {PlainObject} [setting]: 可选参数
- {Function} [success]: 表格创建成功后的回调函数
 
 
 - 
说明:
初始化一个Luckysheet,可包含多个工作表,参考 配置列表
 
refresh([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Function} [success]: 表格刷新成功后的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
刷新canvas
 
destroy([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Function} [success]: 表格释放成功后的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
删除并释放表格
 
getScreenshot([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 
 - {Array | Object | String} [range]: 选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
返回指定选区截图后生成的base64格式的图片
 
setWorkbookName(name [,setting])
- 
参数:
- {Number} [name]: 工作簿名称
 - {PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
说明:
设置工作簿名称
 
undo([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
撤销当前操作,返回刚刚撤销的操作对象
 
redo([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
重做当前操作,返回刚刚重做的操作对象
 
图表
insertChart([setting])
- 
参数:
- {PlainObject} [setting]: 可选参数
- {Array | Object | String} [range]: 图表数据的选区范围,支持选区的格式为
"A1:B2"、"sheetName!A1:B2"或者{row:[0,1],column:[0,1]},只能为单个选区;默认为当前选区 - {Number} [order]: 工作表索引;默认值为当前工作表索引
 - {Function} [success]: 操作结束的回调函数
 
 - {Array | Object | String} [range]: 图表数据的选区范围,支持选区的格式为
 
 - {PlainObject} [setting]: 可选参数
 - 
说明:
指定工作表指定选区范围生成一个图表,返回图表参数对象,包含图表唯一标识符chart id
 
setChart(chartId, attr, value [,setting])
- 
参数:
- 
{String} [chartId]: 指定要修改的图表id
 - 
{String} [attr]: 属性类型
attr可能的值有:"left": 左边到工作表边缘的距离"top": 上边到工作表边缘的距离"width": 图表外框的宽度"height": 图表外框的高度"chartOptions": 图表的详细设置项
 - 
{Number | Object}} [value]: 属性值,当
attr为chartOptions时,直接设置整个chart的配置对象 - 
{PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
修改指定id图表的参数,返回修改后的整个图表参数
 
getChart(chartId)
- 
参数:
- {String} [chartId]: 指定要获取的图表id
 
 - 
说明:
获取指定id图表的参数
 
deleteChart(chartId [,setting])
- 
参数:
- 
{String} [chartId]: 要删除的图表id
 - 
{PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
删除指定id图表,返回被删除的图表的参数
 
公共方法
transToCellData(data [,setting])
- 
参数:
- 
{Array} [data]: data数据
 - 
{PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
data => celldata ,data二维数组数据转化成 {r, c, v}格式一维数组
 
transToData(celldata [,setting])
- 
参数:
- 
{Array} [celldata]: data数据
 - 
{PlainObject} [setting]: 可选参数
- {Function} [success]: 操作结束的回调函数
 
 
 - 
 - 
说明:
celldata => data ,celldata一维数组数据转化成表格所需二维数组
 
toJson()
- 
说明:
导出的json字符串可以直接当作
luckysheet.create(options)初始化工作簿时的参数options使用,使用场景在用户自己操作表格后想要手动保存全部的参数,再去别处初始化这个表格使用,类似一个luckysheet专有格式的导入导出。 
旧版API
::: warning 为保持兼容性,仍然支持旧版API,但是已不推荐使用。 :::
getcellvalue([r] [,c] [,data] [,type])
- 
参数:
- {Number} [r]:单元格所在行数;可选值;从0开始的整数,0表示第一行
 - {Number} [c]:单元格所在列数;可选值;从0开始的整数,0表示第一列
 - {Array} [data]:表数据,二维数组;可选值;默认值为当前表格数据
 - {String} [type]:单元格属性值;可选值;默认值为'v',表示获取单元格的实际值
 
 - 
说明:
此方法为获取单元格的值。
- luckysheet.getcellvalue():返回当前工作表的所有数据;
 - luckysheet.getcellvalue(0):返回当前工作表第1行数据;
 - luckysheet.getcellvalue(null,0):返回当前工作表第1列数据;
 - luckysheet.getcellvalue(0,0):返回当前工作表第1行第1列单元格的数据的v值;
 - luckysheet.getcellvalue(1,1,null,'m'): 返回指定data数据的第2行第2列单元格的原始值。
 
特殊情况:单元格格式为yyyy-MM-dd,type为'v'时会强制取'm'显示值
推荐使用新API: getCellValue
 
getluckysheetfile()
- 
说明:
返回所有表格数据结构的一维数组
luckysheetfile推荐使用新API: getLuckysheetfile
 
getconfig()
- 
说明:
快捷返回当前表格config配置,每个工作表的config信息仍然包含在luckysheetfile。
推荐使用新API: getConfig
 
getluckysheet_select_save()
- 
说明:
返回当前选区对象的数组,可能存在多个选区。
推荐使用新API: getRange
 
getdatabyselection([range] [,sheetOrder])
- 
参数:
- {Object} [range]:选区对象,
object: { row: [r1, r2], column: [c1, c2] };默认为当前第一个选区。 - {Number} [sheetOrder]:表格下标,从0开始的整数,0表示第一个表格;默认为当前表格下标。
 
 - {Object} [range]:选区对象,
 - 
说明:
返回某个表格第一个选区的数据。
luckysheet.getdatabyselection(): 返回当前工作表当前选区的数据luckysheet.getdatabyselection(null,1): 返回第2个工作表的当前选区的数据
推荐使用新API: getRangeValue
 
luckysheetrefreshgrid(scrollWidth, scrollHeight)
- 
参数:
- {Number} [scrollWidth]:横向滚动值。默认为当前横向滚动位置。
 - {Number} [scrollHeight]:纵向滚动值。默认为当前纵向滚动位置。
 
 - 
说明:
按照scrollWidth, scrollHeight刷新canvas展示数据。
 
setcellvalue(r, c, d, v)
- 
参数:
- {Number} [r]:单元格所在行数;从0开始的整数,0表示第一行。
 - {Number} [c]:单元格所在列数;从0开始的整数,0表示第一列。
 - {Array} [d]:表数据;可选值;二维数组。
 - {Object | String | Number} [v]:要设置的值;可为对象,对象是是要符合单元格对象格式。
 
 - 
说明:
设置某个单元格的值。可配合
luckysheet.jfrefreshgrid()刷新查看单元格值改变。luckysheet.setcellvalue(0, 0, luckysheet.flowdata(), 'abc'); luckysheet.jfrefreshgrid(); 
jfrefreshgrid()
- 
说明:
刷新canvas
推荐使用新API: refresh
 
setluckysheet_select_save(v)
- 
参数:
- {Array} [v]:要设置的选区值(数组)。符合选区格式规则,如
[{ row: [r1, r2], column: [c1, c2] }]。 
 - {Array} [v]:要设置的选区值(数组)。符合选区格式规则,如
 - 
说明:
设置当前表格选区的值。配合
luckysheet.selectHightlightShow()可在界面查看选区改变。luckysheet.setluckysheet_select_save([{ row: [0, 1], column: [0, 1] }]); luckysheet.selectHightlightShow();> 推荐使用新API:<a href='#setRangeShow'>setRangeShow</a> 
selectHightlightShow()
- 
说明:
高亮当前选区
推荐使用新API:setRangeShow
 
flowdata()
- 
说明:
快捷获取当前表格的数据
推荐使用新API:getSheetData
 
buildGridData(file)
- 
参数:
- {Object} [file]:luckysheetfile
 
 - 
说明:
生成表格可以识别的二维数组
推荐使用新API:transToData
 
getGridData(data)
- 
参数:
- {Array} [data]:工作表的二维数组数据
 
 - 
说明:
二维数组数据转化成
{r, c, v}格式 一维数组推荐使用新API:transToCellData