Derrick.Jiao 发表于 2021-3-16 16:11:23

SpreadJS在线表格编辑器自定义菜单栏 -- 格式刷

本帖最后由 DerrickJiao 于 2021-3-16 16:19 编辑

用过Excel的小伙伴应该对格式刷不陌生,格式刷可以给我们使用模板的时候带来便利,可以快速地为指定区域添加想要的格式。那么本期教程就教大家如何在组件化编辑器中实现格式刷的功能。

这边需要用到的东西有组件版编辑器、jQuery(为了方便实现,这边就用jQuery,不想用jQuery的小伙伴可以把jQuery里要用的方法用js封装一下就行)、SelectionChanged事件以及js的mousemove事件。

首先是在ribbon中添加我们的格式刷命令,也就是在我们的config.js中添加


接着就是在我们commandMap注册这个命令
    brush: {
                title: "格式刷",
                iconClass: "ribbon-button-brush",
                commandName: "brush",
                execute: async (context, propertyName, fontItalicChecked) => {
                        var sheet = spread.getActiveSheet();
                        var selectionRange = sheet.getSelections();
                              if (selectionRange.length > 1) {
                                          alert("无法对多重选择区域执行此操作");
                                           return;
                               }

                               if (isFormatPainting) {
                                          resetFormatPainting(sheet);
                                          return;
                               }

                              fromRange = selectionRange;
                              fromSheet = sheet;
                              isFormatPainting = true;
                           }
}
定义几个flag用于格式刷的标记
var fromRange, fromSheet, isFormatPainting = false;

                        function resetFormatPainting(sheet) {
                  isFormatPainting = false;
                }
通过SelectionChanged格式刷添加选区的操作,也就是复制格式的操作,里面调用了clipboardPaste命令spread.bind(GC.Spread.Sheets.Events.SelectionChanged, function(e, info) {
                              if (isFormatPainting) {
                                        var sheet = spread.getActiveSheet();
                                        resetFormatPainting(sheet);
                                        sheet.isPaintSuspended(true);
                                        var toRange = sheet.getSelections();


                                        //toRange biger than fromRange
                                        if (fromRange.rowCount > toRange.rowCount) {
                                                toRange.rowCount = fromRange.rowCount;
                                        }
                                        if (fromRange.colCount > toRange.colCount) {
                                                toRange.colCount = fromRange.colCount;
                                        }
                                        //toRange must in Sheet
                                        if (toRange.row + toRange.rowCount > sheet.getRowCount()) {
                                                toRange.rowCount = sheet.getRowCount() - toRange.row;
                                        }
                                        if (toRange.col + toRange.colCount > sheet.getColumnCount()) {
                                                toRange.colCount = sheet.getColumnCount() - toRange.col;
                                        }

                                        var rowStep = fromRange.rowCount,
                                                colStep = fromRange.colCount;
                                        var endRow = toRange.row + toRange.rowCount - 1,
                                                endCol = toRange.col + toRange.colCount - 1;

                                        // if toRange bigger than fromRange, repeat paint
                                        for (var startRow = toRange.row; startRow <= endRow; startRow = startRow + rowStep) {
                                                for (var startCol = toRange.col; startCol <= endCol; startCol = startCol + colStep) {

                                                      var rowCount = startRow + rowStep > endRow + 1 ? endRow - startRow + 1 : rowStep;
                                                      var colCount = startCol + colStep > endCol + 1 ? endCol - startCol + 1 : colStep;
                                                      // sheet.copyTo(fromRange.row,fromRange.col, startRow, startCol, rowCount, colCount,GC.Spread.Sheets.CopyToOptions.style | GC.Spread.Sheets.CopyToOptions.span);
                                                      var fromRanges = new GC.Spread.Sheets.Range(fromRange.row, fromRange.col, rowCount, colCount);
                                                      var pastedRange = new GC.Spread.Sheets.Range(startRow, startCol, rowCount, colCount);
                                                      spread.commandManager().execute({
                                                                cmd: "clipboardPaste",
                                                                sheetName: sheet.name(),
                                                                fromSheet: fromSheet,
                                                                fromRanges: ,
                                                                pastedRanges: ,
                                                                isCutting: false,
                                                                clipboardText: "",
                                                                pasteOption: GC.Spread.Sheets.ClipboardPasteOptions.formatting
                                                      });
                                                }
                                        }

                                        sheet.isPaintSuspended(false);
                              }
                     });

我们要想在移动鼠标的时候显示刷子就需要添加对应DOM
<img id="brushIcon" src="" style="position:absolute;z-index:10000; height:20px; display:none">

然后监听鼠标移动的事件mousemove,将格式刷图表跟随鼠标移动
document.addEventListener('mousemove', function (e) {
         var e = e ? e : window.event;
         if (!isFormatPainting) {
               $("#brushIcon").hide();
                           return;
         }
         var posx = e.pageX;
         var posy = e.pageY;

         var offset = $("#ss").offset();
         if (posx > offset.left && posy > offset.top &&
                     posx < offset.left + $("#ss").width() && posy < offset.top + $("#ss").height()) {
                     var brushIcon = $("#brushIcon");
                     brushIcon.show();
                     brushIcon.css("left", posx + 12 + "px");
                     brushIcon.css("top", posy + "px");
         } else {
                     $("#brushIcon").hide();
         }
                              
})

下载附件即可查看源码

crawler 发表于 2021-3-18 23:14:36

双击格式刷可以一直为格式刷状态吗

Derrick.Jiao 发表于 2021-3-19 09:20:28

crawler 发表于 2021-3-18 23:14
双击格式刷可以一直为格式刷状态吗

目前只能选一次刷一次

crawler 发表于 2021-3-19 14:29:50

DerrickJiao 发表于 2021-3-19 09:20
目前只能选一次刷一次

wps,和office 都可以双击 一致为 格式刷状态,我们可以自己开发吗

Derrick.Jiao 发表于 2021-3-19 14:39:15

crawler 发表于 2021-3-19 14:29
wps,和office 都可以双击 一致为 格式刷状态,我们可以自己开发吗

暂时无法实现双击,您可以参考上面的demo尝试实现。这个不属于产品的标准功能,需要您二次开发。

crawler 发表于 2021-3-19 16:16:00

DerrickJiao 发表于 2021-3-19 14:39
暂时无法实现双击,您可以参考上面的demo尝试实现。这个不属于产品的标准功能,需要您二次开发。

二次开发能实现也可以

Derrick.Jiao 发表于 2021-3-19 16:28:36

crawler 发表于 2021-3-19 16:16
二次开发能实现也可以

:loap1:
页: [1]
查看完整版本: SpreadJS在线表格编辑器自定义菜单栏 -- 格式刷