与GridJs客户端端协同工作
Contents
 [
      
        Hide
      ]
    与GridJs客户端端协同工作
我们基于x-spreadsheet开发了GridJs客户端。
主要步骤如下:
- 创建x_spreadsheet实例
xs = x_spreadsheet(id, options)
    // the parameters are:
    id:the html node id ,for example :'#gridjs-demo' for the html  <div id="gridjs-demo"></div>
    options: the load options
for example the below code init a gridjs_spreadsheet object.
	xs = x_spreadsheet('#gridjs-demo', {
			updateMode:'server',
			updateUrl:'/GridJs2/UpdateCell',
			mode: 'edit',
			showToolbar: true,
                        local: 'en',
			showContextmenu: true
			})
加载选项的参数:
| 参数 | 描述 | 默认值 | 可选 | 
|---|---|---|---|
| allowSelectTextInTextBoxInReadMode | 在只读模式下是否允许在 TextBox 控件中选择文本。 默认值为 false。 | false | 是 | 
| checkSyntax | 是否对用户输入的文本内容进行语法检查和拼写纠错。 与 setSyntaxCheckUrl 配合使用。 默认值为 false。 | false | 是 | 
| loadingGif | 加载图 images / shapes 时的 GIF 动图 URL。 默认值为 content/img/updating.gif。 | content/img/updating.gif | 是 | 
| local | 设置菜单和工具栏的本地化信息,支持多种语言。 可能的值包括: - en, zh, es, pt, de, ru, nl(英语、中文、西班牙语、葡萄牙语、德语、俄语、荷兰语)- ar, fr, id, it, ja(阿拉伯语、法语、印尼语、意大利语、日语)- ko, th, tr, vi, cht(韩语、泰语、土耳其语、越南语、繁体中文字幕) | en | 是 | 
| mode | 可以是 read或edit;read表示只读电子表格;edit表示可以编辑电子表格。 | 无 | 否 | 
| searchHighlightColor | 搜索关键词的高亮背景色。 颜色必须包括透明度通道。 | #dbe71338 | 是 | 
| showCheckSyntaxButton | 是否在工具栏显示语法检查和拼写纠错按钮。 默认值为 false。 | false | 是 | 
| showContextmenu | 是否在单元格右键点击时显示右键菜单。 默认值为 true。 | true | 是 | 
| showFileName | 是否显示文件名。 | true | 是 | 
| showFormulaExplain | 鼠标悬停时是否显示应用于此单元格的公式说明。 与 setFormulaExplainUrl 配合使用。 默认值为 false。 | false | 是 | 
| showFormulaTip | 鼠标悬停时是否显示应用于此单元格的现有公式。 默认值为 false。 | false | 是 | 
| showNonEditableSymbolInCell | 是否在单元格显示客户端不可编辑符号。 设置为 true 后,点击右键菜单“禁用编辑”后,禁用编辑的区域会显示符号。 默认值为 false。 | false | 是 | 
| showToolbar | 是否显示工具栏。 | true | 是 | 
| updateMode | 目前仅支持 server。 | server | 否 | 
| updateUrl | 根据 JSON 设置服务器端的更新操作 URL。 | 无 | 否 | 
| view | 设置表格视图大小,例如 {width: () => 1000, height: ()=> 500}。 | {width: () => document.documentElement.clientWidth, height: () => document.documentElement.clientHeight } | 是 | 
- 用json数据加载
xs.loadData(data)
// the parameters is:
	data: the json data which describ the data structure for the worksheets
- 通过sheetname设置活动表格
xs.setActiveSheetByName(sheetname)
// the parameters is:
	sheetname: the sheet name 
- 通过id设置活动表格
xs.setActiveSheet(id)
// the parameters is:
	sheetname: the sheet id 
- 设置活动单元
xs.setActiveCell(row,col);
// the parameters are:
	row: the cell row
	col: the cell column
- 设置多个实例的激活状态
xs.setActiveForMultipleInstance(isacitve);
// the parameters are:
	isacitve: whether need to do edit operation at this xs instanse 
// when there are more than one GridJs instances in one page, we need to call this method.
// we only support do edit operation for one instances at a page.
// for example,if we have two instances: xs1 and xs2 in one html page.
// if we need to keep edit operation in xs1,
// we shall call:
xs1.setActiveForMultipleInstance(true);
xs2.setActiveForMultipleInstance(false);
// if we need not do any edit operation for both,
// we shall call:
xs1.setActiveForMultipleInstance(false);
xs2.setActiveForMultipleInstance(false);
- 为服务器端操作的形状/图像操作设置信息
xs.setImageInfo(imageGetActionUrl, imageAddByUploadActionUrl, imageAddByUrlActionUrl, imageCopyActionUrl, zindex, loadingGif);
// the parameters are:
	imageGetActionUrl: the get image action URL in the server side controller
	imageAddByUploadActionUrl: the upload image action  URL in the server side controller
	imageAddByUrlActionUrl: the add image from URL action  URL in the server side controller
	imageCopyActionUrl: the copy image action  URL in the server side controller
	zindex: the minimum zindex of the image in the canvas
	loadingGif (optional): the loading gif url when loading the image/shape .it is optional,the default value is:content/img/updating.gif
    for example: 
            const imageurl = "/GridJs2/imageurl";
            const imageuploadurl1 = "/GridJs2/AddImage";
            const imageuploadurl2 = "/GridJs2/AddImageByURL";
            const imagecopyurl = "/GridJs2/CopyImage";  
	    const basiczorder = 5678;
    xs.setImageInfo(imageurl, imageuploadurl1, imageuploadurl2, imagecopyurl, basiczorder);
- 为服务器端操作设置下载操作的信息
xs.setFileDownloadInfo(downloadActionUrl);
// the parameters are:
	downloadActionUrl: the get download file action URL in the server side controller
    for example: 
            const fileDownloadUrl = "/GridJs2/Download";
            xs.setFileDownloadInfo(fileDownloadUrl);
- 为服务器端操作设置OLE对象操作的信息
xs.setOleDownloadInfo(oleActionUrl);
// the parameters are:
	oleActionUrl: the ole object file action URL in the server side controller
    for example: 
            const oleDownloadUrl = "/GridJs2/Ole";
            xs.setOleDownloadInfo(oleDownloadUrl);
- 设置语法检查和拼写更正操作的服务器端信息
xs.setSyntaxCheckUrl(checkUrl);
// the parameters are:
	checkUrl: the  syntax checking & spell correction operation action URL in the server side controller
    for example: 
            const checkurl = "/GridJs2/CheckSyntax";
            xs.setSyntaxCheckUrl(checkurl);
- 设置公式说明的服务器端信息
xs.setFormulaExplainUrl(formulaExplainUrl);
// the parameters are:
	formulaExplainUrl: the  formula explanation  action URL in the server side controller
    for example: 
            const formulaExplainUrl = "/GridJs2/FormulaExplain";
            xs.setFormulaExplainUrl(formulaExplainUrl);
其他有用的API
- 渲染视图
xs.reRender()
- 获取活动表格的ID
xs.getActiveSheet()
- 设置缩放级别
xs.setZoomLevel(zoom)
// the parameters is:
	zoom:the zoom level ,can be number ,for example 0.5 for zoom out, or 2 for zoom in
- 设置文件名
xs.setFileName(name)
// the parameters is:
	name:the file name with extension ,for example trip.xlsx
- 用于发送邮件功能的回调函数
xs.setEmailSendCallFunction(callback)
// the parameters is:
	callback: the callback function to handle email sending, receives a mailObj parameter
		callback: function(mailObj) {
			// mailObj properties:
			// mailObj.receiver: the email address of the receiver, e.g., 'example@gmail.com'
			// mailObj.type: the format of the file to be sent, can be 'html', 'xlsx', or 'pdf'
		}
- 是否启用GridJs的窗口按键事件
xs.enableKeyEvent(isenable)
// the parameters is:
	isenable:whether the window key event is active for GridJs
//when has other controls in the same page, you may want to ignore the key event in GridJs 
- 取消所有已绑定到GridJs的事件,包括窗口按键事件和窗口调整大小事件
xs.destroy()
- 为图像/形状设置可见过滤器
xs.setVisibleFilter((sheet,s) =>{})
    //  to set a function which return true(for visible) or false(for invisible) for the visible filter with the below parameters :
	sheet:the sheet instance
	s:the image or shape instance
    for example: 
	//this will make visible for image/shape in sheet with name 'Sheet3' and 'Sheet1' except for the 'Rectangle' type
		xs.setVisibleFilter((sheet,s) => { if (sheet.data.name==='Sheet3'||sheet.data.name==='Sheet1') return s.type!=='Rectangle';  return false; })
	//this will make visible for image/shape in sheet with name  'Sheet1' 
		xs.setVisibleFilter((sheet,s) => { if (sheet.data.name==='Sheet1') return true;  return false; })
	//this will make invisible for image/shape in all sheets 
		xs.setVisibleFilter((sheet,s) => {  return false; })
	//if all the image/shape is already loaded and you want to change the visible filter at runtime,you can call the below code to trigger a reload for image/shape
		xs.reRender()
- 获取选定的图像/形状,如果没有选定则返回空
xs.sheet.selector.getObj()
- 在指定单元格位置显示或隐藏 HTML 节点
xs.sheet.showHtmlAtCell(isShow, html, ri, ci, deltaX, deltaY)
    //the parameters are:
    // - isShow: Boolean value indicating whether to show or hide the HTML content.
    // - html: The HTML string to be displayed.
    // - ri: Row index of the target cell.
    // - ci: Column index of the target cell.
    // - deltaX: (Optional) Relative X-position adjustment from the top-left corner of the cell.
    // - deltaY: (Optional) Relative Y-position adjustment from the top-left corner of the cell.
    // Example usage:
    // Show HTML at cell A1
    xs.sheet.showHtmlAtCell(true, "<span>html span</span><input length='30' id='myinput'>test</input>", 0, 0);
    // Hide the HTML node
    xs.sheet.showHtmlAtCell(false);
    // Note: When an HTML node is shown, the default GridJS event handling is disabled to allow interaction with the HTML content.
    // This means you cannot select any cells or perform edit operations until the HTML node is hidden.
- 设置图片/形状的可选状态
const shape=xs.sheet.selector.getObj();
shape.setControlable(isenable)
     // the parameter is:
      isenable: when set to true,the image or shape can be selectable and movable/resizeable
- 获取单元格对象
xs.sheet.data.getCell(ri,ci)
    // the parameters are:
	ri:row index 
	ci:column index
- 获取单元格样式
xs.sheet.data.getCellStyle(ri,ci)
    // the parameters are:
	ri:row index 
	ci:column index
- 设置单元格值
xs.sheet.data.setCellText(ri,ci,value,state)
    // the parameters are:
	ri:row index 
	ci:column index
	value:the cell value
	state: input | finished ,if finished ,it will do update action to servside
- 获取/设置选定的单元格范围
xs.sheet.data.selector.range
- 为选定的单元格或单元格区域设置单元格值
xs.sheet.data.setSelectedCellText(value)
    // the parameters are:
	value:the  value for the cell
- 为选定的单元格或单元格区域设置样式
xs.sheet.data.setSelectedCellAttr(attributename,value)
    // the parameters are:
	attributename:font-name | font-bold | font-italic | font-size  | format|border|merge|formula |strike|textwrap |underline |align |valign |color|bgcolor|pattern
	value:the  value for the attribute
- 合并选定的单元格区域
xs.sheet.data.merge()
- 取消合并选定的单元格区域
xs.sheet.data.unmerge()
- 删除所选单元格
xs.sheet.data.deleteCell(type)
    // the parameters are:
	type:all|format  all: means delete the cell and clear the style ;format means delete the cell value and keep the cell style
- 设置冻结窗格
xs.sheet.data.setFreeze(ri,ci)
    // the parameters are:
	ri:row index 
	ci:column index
- 在所选单元格处插入行或列
xs.sheet.data.insert(type, n)
    // the parameters are:
	type: row | column
	n:the row or column number
- 在所选单元格处删除行或列
xs.sheet.data.delete(type)
    // the parameters are:
	type: row | column
- 设置列的宽度
xs.sheet.data.setColWidth(ci,width)
    // the parameters are:
	ci:column index
	width:the width for the column
- 设置列的宽度
xs.sheet.data.setColsWidth(sci,eci,width)
    // the parameters are:
	sci:the start column index
	eci:the end column index
	width:the width for the column
- 设置所有列的宽度
xs.sheet.data.setAllColsWidth(width)
    // the parameters are:
	width:the width for the columns
- 获取列的宽度
xs.sheet.data.cols.sumWidth(min,max)
    // the parameters are:
	min:the start column index
	max:the end column index,not include
- 设置行的高度
xs.sheet.data.setRowHeight(ri,height)
    // the parameters are:
	ri:row index
	height:the height for the row
- 设置行的高度
xs.sheet.data.setRowsHeight(sri,eri,height)
    // the parameters are:
	sri:start row index
	eri:end row index
	height:the height for the rows
- 设置所有行的高度
xs.sheet.data.setAllRowsHeight(height)
    // the parameters are:
	height:the height for the rows
- 获取行的高度
xs.sheet.data.rows.sumHeight(min,max)
    // the parameters are:
	min:the start row index
	max:the end row index,not include
- 获取/设置显示方向
xs.sheet.data.displayRight2Left
事件回调
- 我们可以追踪以下事件
 xs.on('cell-selected', (cell, ri, ci) => {
                console.log('cell selected:', cell, ', ri:', ri, ', ci:', ci);
                if (ci === -1) {
                    console.log('ci === -1 means a row selected ',ri);
                }
                if (ri === -1) {
                    console.log('ri === -1 means a column selected',ci);
                }
            }).on('cells-selected', (cell, range) => {
                console.log('range   selected:', cell, ', rang:', range);
            }).on('object-selected', (shapeOrImageObj) => {
                console.log('shape or image selected id:', shapeOrImageObj.id, ', type: ', shapeOrImageObj.type);
            }).on('sheet-selected', (id,name) => {
                console.log('sheet selected id:', id, ', name: ',name);
            }).on('sheet-loaded', (id,name) => {
                console.log('sheet load finished:', id, ', name: ',name);
            }).on('cell-edited', (text, ri, ci) => {
	        //just edit the cell
                console.log('text:', text, ', ri: ', ri, ', ci:', ci);
            }).on('cells-updated', (name, cells) => {
	       //cell value got updated
                console.log('cells updated for sheet name:', name);
                cells.forEach((acell, index, array) => {
                console.log('acell got updated:', acell);
            })
            }).on('cells-deleted', (range) => {
                console.log('cells deleted :', range);
            }).on('rows-deleted', (ri, n) => {
                console.log('rows-deleted :', ri, ",size", n);
            }).on('columns-deleted', (ci, n) => {
                console.log('columns-deleted :', ci, ",size", n);
            }).on('rows-inserted', (ri, n) => {
                console.log('rows-inserted :', ri, ",size", n);
            }).on('columns-inserted', (ci, n) => {
                console.log('columns-inserted :', ci, ",size", n);
            });
- 预检事件 如果返回 false,插入/删除操作将不会继续。
  xs.checkRowInsert = (ri, size) => { if (ri % 2 == 1) return true; else return false; };
  xs.checkColumnInsert = (ci, size) => { if (ci % 2 == 1) return true; else return false; };
  xs.checkRowDelete = (ri, size) => { if (ri % 2 == 1) return true; else return false; };
  xs.checkColumnDelete = (ci, size) => { if (ci % 2 == 1) return true; else return false; };
自定义
- 设置主页图标和链接
xs.sheet.menubar.icon.setHomeIcon(iconUrl,targetUrl)
    // the parameters are:
	iconUrl:the home icon URL
	targetUrl:the target link URL
	for example ,the below code will set the new logo and with link to google.com
	xs.sheet.menubar.icon.setHomeIcon('https://forum.aspose.com/letter_avatar_proxy/v4/letter/y/3e96dc/45.png','https://www.google.com')
- 显示菜单栏
xs.sheet.menubar.show()
- 隐藏菜单栏
xs.sheet.menubar.hide()
用于TextBox对象的API
TextBox是一种特殊类型的形状,其类型属性为:“TextBox” 例如:以下代码将显示哪种形状是文本框
for (let shape of xs.sheet.data.shapes) {
    if (shape.type === 'TextBox') {
        console.log(shape.id + ' is a textbox');
    }
}
- 更改文本框对象的背景颜色
    setBackgroundColor(color)
    // the parameters are:
        color: the html color value in hex string value
    //for example,we assume shape 0 is a textbox object,this will set the background color to Yellow 
     const textbox=xs.sheet.data.shapes[0];
     textbox.setBackgroundColor('#FFFF00');
- 自动更改背景颜色和文本颜色以实现视觉效果
    setActiveEffect(boolvalue)
    // the parameters are:
        boolvalue: if true,will change background color and the text color of the textbox object;if false,restore to original appearence
- 隐藏/显示文本框对象中的文本内容
    hideText(boolvalue)
    // the parameters are:
        boolvalue: if true,will not display the text in the textbox object;if false,restore to original appearence
有关详细信息,您可以在此处查看示例 https://github.com/aspose-cells/Aspose.Cells-for-.NET/tree/master/Examples_GridJs