找回密码
 立即注册

QQ登录

只需一步,快速开始

IwantU

金牌服务用户

31

主题

106

帖子

532

积分

金牌服务用户

积分
532

微信认证勋章

IwantU
金牌服务用户   /  发表于:2017-2-9 11:17  /   查看:5329  /  回复:5
新增一个sheet的时候 所有这个sheet的单元默认是锁定的 如何 让它不锁定

5 个回复

倒序浏览
dexteryao讲师达人认证 悬赏达人认证 SpreadJS 开发认证
超级版主   /  发表于:2017-2-9 11:38:05
沙发
在点击新增Sheet 或者通过代码新增Sheets 后,设置Sheet的 default style loccked 为 false

点击新增sheet 的事件为 SheetTabClick 当sheetTabIndex : -1 时时新增
设置默认style 请参考http://blog.gcpowertools.com.cn/ ... BC%96%E8%BE%91.aspx
回复 使用道具 举报
IwantU
金牌服务用户   /  发表于:2017-2-9 12:56:27
板凳
点击新增sheet 的事件为 SheetTabClick 当sheetTabIndex : -1 时时新增 ???怎么用??给个例子或者这个应该是个方法 我把这个方法放在那里 在线表格设计器v9全局才可以生效?
回复 使用道具 举报
dexteryao讲师达人认证 悬赏达人认证 SpreadJS 开发认证
超级版主   /  发表于:2017-2-9 14:16:21
地板
在  spradWrapper.js 中, 您修改下 ActiveSheetChanged
  1.                     wrapper.spread.bind(GcSpread.Sheets.Events.SheetTabClick, function (e, args) {
  2.                         if(args.sheetTabIndex === -1){
  3.                             wrapper.isAddNewSheet = true;
  4.                         }
  5.                     });                    
  6.                     wrapper.spread.bind(Sheets.Events.ActiveSheetChanged, function(e, args){
  7.                         fileModifiedCallback()
  8.                         if(wrapper.isAddNewSheet){
  9.                             wrapper.isAddNewSheet = false;
  10.                             var newSheet = args.newSheet;

  11.                             //set sheet detault lock false
  12.                             var defaultSheetStyle = newSheet.getDefaultStyle() || new Sheets.Style();
  13.                             defaultSheetStyle.locked = false;
  14.                             newSheet.setDefaultStyle(defaultSheetStyle);
  15.                         }
  16.                     });
复制代码
回复 使用道具 举报
IwantU
金牌服务用户   /  发表于:2017-2-9 14:57:14
5#
/// <reference path="../lib/libraries.d.ts" />
/// <reference path="../common/asyncLoader.ts" />
var GcSpread;
(function (GcSpread) {
    var Sheets;
    (function (Sheets) {
        var designer;
        (function (designer) {
            var wrapper;
            (function (wrapper) {
                'use strict';
                var element;
                function getThemeColors() {
                    var themeColor = wrapper.spread.getActiveSheet().currentTheme().colors();
                    return [
                        {
                            name: 'Background 1',
                            baseColor: themeColor.getColor('Background 1')
                        },
                        {
                            name: 'Text 1',
                            baseColor: themeColor.getColor('Text 1')
                        },
                        {
                            name: 'Background 2',
                            baseColor: themeColor.getColor('Background 2')
                        },
                        {
                            name: 'Text 2',
                            baseColor: themeColor.getColor('Text 2')
                        },
                        {
                            name: 'Accent 1',
                            baseColor: themeColor.getColor('Accent 1')
                        },
                        {
                            name: 'Accent 2',
                            baseColor: themeColor.getColor('Accent 2')
                        },
                        {
                            name: 'Accent 3',
                            baseColor: themeColor.getColor('Accent 3')
                        },
                        {
                            name: 'Accent 4',
                            baseColor: themeColor.getColor('Accent 4')
                        },
                        {
                            name: 'Accent 5',
                            baseColor: themeColor.getColor('Accent 5')
                        },
                        {
                            name: 'Accent 6',
                            baseColor: themeColor.getColor('Accent 6')
                        }
                    ];
                }
                wrapper.getThemeColors = getThemeColors;
                function reset(init) {
                    if (init === void 0) { init = false; }
                    if (!init) {
                        wrapper.spread.destroy();
                        element.empty();
                        wrapper.spread = null;
                    }  
                    wrapper.spread = new Sheets.Spread(element[0], { sheetCount: 1 });
                    wrapper.spreadElement = element;
                    designer.formulaBar.initFormulaBar(init);
                 
                    designer.contextMenu.addTabStripEvents();
                    //Register F2 key to enter editing status.
                    for (var i = 0; i < wrapper.spread.getSheetCount(); i++) {
                        var sheet = wrapper.spread.sheets[i];
                        sheet.addKeyMap(113, false, false, false, false, function () {
                            if (!this.isEditing()) {
                                this.startEdit();
                            }
                        });
                        //新增
                        //set sheet detault lock false
                        var defaultSheetStyle = sheet.getDefaultStyle() || new Sheets.Style();
                        defaultSheetStyle.locked = false;
                        sheet.setDefaultStyle(defaultSheetStyle);
                    }
                    var fileModifiedCallback = function () {
                        designer.actions.isFileModified = true;
                        designer.actions.updateWindowTitle();
                    };
                    wrapper.spread.bind(Sheets.Events.CellChanged, fileModifiedCallback);
                    wrapper.spread.bind(Sheets.Events.RowChanged, fileModifiedCallback);
                    wrapper.spread.bind(Sheets.Events.ColumnChanged, fileModifiedCallback);
                    wrapper.spread.bind(Sheets.Events.ActiveSheetChanged, fileModifiedCallback);
                    wrapper.spread.bind(Sheets.Events.InvalidOperation, function (e, args) {
                        if (args.invalidType === Sheets.InvalidOperationType.ChangeSheetName) {
                            designer.MessageBox.show(args.message, designer.res.title, designer.MessageBoxIcon.error);
                        }
                    });
                    wrapper.spread.bind(GcSpread.Sheets.Events.CustomFloatingObjectLoaded, function (event, args) {
                        bindSlicerContextmenu(wrapper.spread, args.customFloatingObject, args.element);
                    });
                    wrapper.spread.bind(GcSpread.Sheets.Events.RangeChanged, function (event, args) {
                        var sheet = wrapper.spread.getActiveSheet();
                        var row = sheet.getActiveRowIndex();
                        var col = sheet.getActiveColumnIndex();
                        if (args.action === GcSpread.Sheets.RangeChangedAction.DragDrop) {
                            $(".ribbon-bar").gcuiribbon("setTabPageVisible", "tableTab", sheet.findTable(row, col));
                        }
                        if (args.action === GcSpread.Sheets.RangeChangedAction.Clear) {
                            hideRibbonDesignTab();
                            if (sheet.findTable(row, col)) {
                                // If sparkline is in table, table tab should be selected when sparkline is deleted.
                                $(".ribbon-bar").gcuiribbon("setTabPageVisible", "tableTab", true);
                                $(".ribbon-bar").gcuitabs("select", "tableTab");
                                return;
                            }
                            // When table is deleted, insert table button should be enabled.
                            $(".ribbon-bar").gcuiribbon("setButtonDisabled", "insert-table", false);
                            // Change to home tab when table or sparkline is deleted.
                            $(".ribbon-bar").gcuiribbon("setTabPageVisible", "homeTab", true);
                            $(".ribbon-bar").gcuitabs("select", "homeTab");
                        }
                    });
                    wrapper.spread.bind(GcSpread.Sheets.Events.FloatingObjectRemoved, function (event, args) {
                        if (args.floatingObject instanceof Sheets.Slicer) {
                            hideRibbonDesignTab();
                            var sheet = wrapper.spread.getActiveSheet();
                            var row = sheet.getActiveRowIndex();
                            var col = sheet.getActiveColumnIndex();
                            // Change ribbon tab when slicer is deleted.
                            if (sheet.findTable(row, col)) {
                                $(".ribbon-bar").gcuiribbon("setTabPageVisible", "tableTab", true);
                                $(".ribbon-bar").gcuitabs("select", "tableTab");
                            }
                            else {
                                $(".ribbon-bar").gcuiribbon("setTabPageVisible", "homeTab", true);
                                $(".ribbon-bar").gcuitabs("select", "homeTab");
                            }
                        }
                    });
                    // init table custom style and slicer custom style
                    initCustomStyle();
                    designer.ribbon.attachEvent();
                    setFocusToSpread();
                    designer.ribbon.resetSpreadNamedStyle();
                }
                wrapper.reset = reset;
                function hideRibbonDesignTab() {
                    // File tab will show in Qt designer, so the first hidden tab number is 6.
                    var LAST_SHOW_TAB_NUMBER = 6;
                    $(".ribbon-bar>ul").find("li:gt(" + LAST_SHOW_TAB_NUMBER + ")").css("display", "none");
                    $(".ribbon-bar>div:gt(" + LAST_SHOW_TAB_NUMBER + ")").attr("aria-hidden", true);
                }
                function initCustomStyle() {
                    $(".custom-format-table").css("display", "none");
                    $(".custom-preview").find(".table-format-preview").css("display", "none");
                    designer.FormatTableDialog.customTableStyle = {};
                    designer.FormatTableDialog.currentId = 1;
                    $(".custom-format-slicer").css("display", "none");
                    $(".slicer-custom-preview").find(".slicer-format-preview").css("display", "none");
                    designer.SlicerStyleDialog.customSlicerStyle = {};
                    designer.SlicerStyleDialog.currentId = 1;
                }
                function setSelectedSlicerContextmenuName() {
                    var selectedSlicerName;
                    var sheet = wrapper.spread.getActiveSheet();
                    var selectedSlicers = designer.util.getSelectedSlicers(sheet);
                    if (!selectedSlicers || selectedSlicers.length === 0) {
                        return;
                    }
                    else if (selectedSlicers.length === 1) {
                        var slicer = selectedSlicers[0];
                        selectedSlicerName = slicer.captionName();
                        selectedSlicerName = "\"" + selectedSlicerName + "\"";
                    }
                    else {
                        selectedSlicerName = "Slicers";
                    }
                    return selectedSlicerName;
                }
                function bindSlicerContextmenu(spread, slicer, element) {
                    var customFloatingObject = slicer;
                    var $contextmenuWidth = $(".slicer-contextmenu-width");
                    var $nameContainer = $("#name-container");
                    var BASIC_WIDTH_TO_CHANGE = 100; //The basic width to change slicer contextmenu.
                    var MINIMUM_CONTEXTMENU_WIDTH = 175; //The minimum width of slicer contextmenu.
                    var MAX_NAME_SHOW_WIDTH = 400; //The max caption name width to show.
                    if (!(customFloatingObject instanceof Sheets.Slicer)) {
                        return;
                    }
                    var htmlElement = element;
                    $(htmlElement).bind("contextmenu", function (evt) {
                        var sheet = spread.getActiveSheet();
                        if (sheet.getIsProtected() && customFloatingObject.isLocked() && !sheet.protectionOption().allowEditObjects) {
                            Sheets.util.cancelDefault(evt);
                            return;
                        }
                        var nameWidth;
                        var newCaptionName = setSelectedSlicerContextmenuName();
                        if (newCaptionName === undefined) {
                            return;
                        }
                        $contextmenuWidth.removeClass("hidden");
                        $nameContainer.text(newCaptionName);
                        nameWidth = $nameContainer.width();
                        if (nameWidth > MAX_NAME_SHOW_WIDTH) {
                            nameWidth = MAX_NAME_SHOW_WIDTH;
                            newCaptionName = formatCaptionName($contextmenuWidth, $nameContainer, newCaptionName, MAX_NAME_SHOW_WIDTH);
                        }
                        $("#removedSlicerName").text(designer.res.contextMenu.remove + " " + newCaptionName);
                        var contextmenuWidth = nameWidth + BASIC_WIDTH_TO_CHANGE;
                        if (contextmenuWidth < MINIMUM_CONTEXTMENU_WIDTH) {
                            $("#slicer-menu").width(MINIMUM_CONTEXTMENU_WIDTH);
                        }
                        else {
                            $("#slicer-menu").width(contextmenuWidth);
                        }
                        $contextmenuWidth.addClass("hidden");
                        $(".context-menu").removeClass("hidden");
                        $("#slicer-menu").removeClass("hidden");
                        $("#tabstrip-menu").addClass("hidden");
                        $("#sheet-menu").addClass("hidden");
                        $("#comment-menu").addClass("hidden");
                        $("#slicer-menu").position({
                            my: "left top",
                            of: evt
                        });
                        Sheets.util.cancelDefault(evt);
                    });
                }
                function formatCaptionName(nameSelector, containerSelector, name, maxWidth) {
                    if (!name) {
                        return;
                    }
                    if (name.length < 20) {
                        return;
                    }
                    var STEP = 5;
                    if (nameSelector.hasClass("hidden")) {
                        nameSelector.removeClass("hidden");
                    }
                    var length = name.length;
                    var nameWidth;
                    while (length > 0) {
                        name = name.substring(0, length - STEP) + "...";
                        containerSelector.text(name);
                        nameWidth = containerSelector.width();
                        if (nameWidth < maxWidth) {
                            break;
                        }
                        length = name.length;
                    }
                    name = "\"" + name + "\"";
                    return name;
                }
                function setFocusToSpread() {
                    if (wrapper.spread.getActiveSheet()) {
                        wrapper.spread.focus(true);
                    }
                }
                wrapper.setFocusToSpread = setFocusToSpread;
                designer.loader.ready(function () {
                    element = $(".spreadWrapper .ss");
                    reset(true);
                });
            })(wrapper = designer.wrapper || (designer.wrapper = {}));
        })(designer = Sheets.designer || (Sheets.designer = {}));
    })(Sheets = GcSpread.Sheets || (GcSpread.Sheets = {}));
})(GcSpread || (GcSpread = {}));


这个是spreadWrapper.js 没有ActiveSheetChanged这个方法
回复 使用道具 举报
dexteryao讲师达人认证 悬赏达人认证 SpreadJS 开发认证
超级版主   /  发表于:2017-2-9 15:55:57
6#
wrapper.spread.bind(Sheets.Events.ActiveSheetChanged, fileModifiedCallback);
这句
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 立即注册
返回顶部