[{"id":"1b88a165-2563-437e-99bb-ae30bd4b56db","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a244ead7-a2c6-47a3-ac17-c5dbfa337362","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"33638a1c-7196-42c1-a96d-38b2d9ba8ac4","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"8e72e33e-b4ab-4fb3-98fc-a0b148134aed","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"86662220-9b9e-4940-9ced-d22642ea49a8","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"55fd3bb8-18d4-4edb-9640-ca3a365b798f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"760b37c7-c713-4b24-b9ba-4bfe7d8437a6","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"3a083583-1d5f-492b-b450-34b2b5c775b8","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"04e73782-aa78-4dfe-a4f9-e72ed4c78a11","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"57c94653-8893-403b-a5b1-0d1e33a0bd0f","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"09a66339-64c0-415c-b142-0691587a8e4a","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"5b7aeac5-c755-426a-95c7-1ae8e547179a","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"790bc77a-9216-48fd-b8f9-fbc374ebb155","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"900e6cab-065d-4f1c-844d-efa3c074e270","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"0baaf91d-84f6-404c-a487-735226b6d5b6","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"5d37413b-3600-4da9-9700-feea54355f59","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"7ded3a22-15eb-49b8-a488-e83c2cd872eb","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"89c707ed-9841-4e53-96fb-940cc3214804","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a570c8e7-07a2-47da-965b-da44fd1fa5cf","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"a5a73576-16ea-4cbc-925c-ef547389eaa5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"69e79655-e015-4f9a-a230-2a25c988c926","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"adf3817f-7667-4a4c-8a5f-767b0b7e1e3e","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"1126cfab-6210-4e28-bee0-02c113fb7a0c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"63c577e6-6cf9-497e-94e1-2307f7d3f498","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"24769ecd-2b08-4a85-b318-4f533bbf8393","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"2605431b-dc80-491d-886e-28981595d277","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"4f41e22e-eb51-49e5-aeae-a42dd6bf352c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"aa71a884-c5bc-4842-8d6a-873dfd645167","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"b0576ca2-cb84-4390-9f95-9354ec20eda5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"dacc7931-6785-4675-be31-80930403cf7b","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"c90d5fdf-420f-4978-8bf5-c9a2bb4334b3","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"6e6ac5b1-1501-4e28-89cc-525139488537","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"ff052704-1389-4029-bcdd-73c6cbe9f807","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"21c6131f-0f2d-41d1-9284-6ad9ee803c1f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"64e2f4a3-2303-4bfa-8a93-6c23ef01de58","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"4a0842a3-20b1-40c3-8e00-cd5941ffdf53","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]}]
        
(Showing Draft Content)

自定义切片器

您可以使用 GeneralSlicerData 类或 TableSlicerData 类自定义切片器。

GeneralSlicerData 类用于处理二维数组的数据。 该类提供可用于筛选数据并获得筛选结果的属性和方法。 您可以将多个切片器附加到自定义切片器。 每个切片器可以筛选一列数据。 筛选完成后,其他切片器将由 GeneralSlicerData 类通知。 然后,切片器可以从 GeneralSlicerData 获取筛选后的结果,并更新其UI。

切片器与 GeneralSlicerData 类基于以下步骤共同使用:

  • 使用您的数据创建一个新的 GeneralSlicerData
  • 创建一个新的自定义切片器,并将其附加到 GeneralSlicerData
  • GeneralSlicerData 获取列数据,并构建切片器UI。
  • 响应UI事件并调用 GeneralSlicerDatadoFilter 方法。
  • GeneralSlicerData 获取筛选后的结果,并更新切片器UI。

您可以使用 getData 方法来获取特定列的所有数据。 您可以使用 getExclusiveData 方法获取专有(非重复数据)。 您可以使用 doFilter 方法筛选列,或使用 doUnfilter 方法。 有关方法的完整列表,请参考 GeneralSlicerData 类。

您可以使用 attachListener 函数将侦听器附加到 GeneralSlicerData ,并使用 detachListener 函数。

下图显示了一个自定义切片器。

示例代码

本示例创建一个自定义切片器。

<!DOCTYPE html>
<html>
<head>
 <title>SpreadJS Sample</title>
     <link href="./css/gc.spread.sheets.excel2013white.13.0.0.css" rel="stylesheet" type="text/css" />
     <script src="http://code.jquery.com/jquery-2.0.2.js" type="text/javascript"></script>
     <script src="./scripts/gc.spread.sheets.all.13.0.0.min.js"></script>
    <script type="text/javascript">
     //定义数据源。
         columnNames = ["Name", "City", "Birthday"];
     data = [
         ["Bob", "NewYork", "1968/6/8"],
         ["Betty", "Washington", "1972/7/3"],
         ["Alice", "NewYork", "1964/3/2"]];
    //定义自定义切片器。
         function MySlicer(container) {
         this.container = container;
         this.slicerData = null;
         this.columnName = null;
     }
     MySlicer.prototype.setData = function (slicerData, columnName) {
         this.slicerData = slicerData;
         this.columnName = columnName;
         this.slicerData.attachListener(this);
         this.onDataLoaded();
     }
     MySlicer.prototype.onDataLoaded = function () {
         //创建切片器dom树。
             var columnName = this.columnName,
         exclusiveData = this.slicerData.getExclusiveData(columnName);
         $(this.container).append($('<span>' + this.columnName + ':</span>' + '<br />'));
         var domString = "";
         for (var i = 0; i < exclusiveData.length; i++) {
             domString += '<input type="checkbox" name="' + columnName + '" value="' + exclusiveData[i] + '">';
             domString += '<span>' + exclusiveData[i] + '</span>';
             domString += '<br />';
         }
         $(this.container).append($(domString));
         //将事件附加到dom。
             var self = this;
         $("[name='" + self.columnName + "']").change(function () {
             var slicer = self,
             exclusiveData = slicer.slicerData.getExclusiveData(slicer.columnName),
             parent = $(this).parent(),
             items = parent.children(),
             indexes = [];
             for (var i = 0, length = items.length; i < length; i++) {
                 if (items[i].checked) {
                     var value = items[i].value;
                     if (!isNaN(parseInt(value))) {
                         value = parseInt(value);
                     }
                     indexes.push(exclusiveData.indexOf(value))
                 }
             }
             if (indexes.length === 0) {
                 slicer.slicerData.doUnfilter(slicer.columnName);
             } else {
                 slicer.slicerData.doFilter(slicer.columnName, { exclusiveRowIndexes: indexes });
             }
         });
     };
     MySlicer.prototype.onFiltered = function () {
         //以下是显示筛选结果的示例。
             var slicerdata = this.slicerData;
         var filteredRowIndexs = slicerdata.getFilteredRowIndexes();
         var trs = $listTable.find("tr");
         for (var i = 0; i < slicerdata.data.length; i++) {
             if (filteredRowIndexs.indexOf(i) !== -1) {
                 $(trs[i + 1]).show();
             } else {
                 $(trs[i + 1]).hide();
             }
         }
     }
    //定义显示筛选结果方法。
         function initFilteredResultList() {
         var tableStr = "<table border='1' cellpadding='0' cellspacing='0'><tr>";
         for (var i = 0; i < columnNames.length; i++) {
             tableStr += "<th>" + columnNames[i] + "</th>";
         }
         tableStr += "</tr>";
         for (var i = 0; i < data.length; i++) {
             tableStr += "<tr>";
             for (var j = 0; j < data[i].length; j++) {
                 tableStr += "<td>" + data[i][j] + "</td>";
             }
             tableStr += "</tr>";
         }
         tableStr += "</table>";
         $listTable = $(tableStr);
         $("#list").append($listTable);
     }
    $(document).ready(function () {
         //初始化筛选结果列表。
             initFilteredResultList();
         //创建一个自定义切片器,然后将此切片器添加到“ slicerContainer” div中。
             var slicer = new MySlicer($("#slicerContainer")[0]);
         var slicerData = new GC.Spread.Slicers.GeneralSlicerData(data, columnNames);
         slicer.setData(slicerData, "Name");
     });
 </script>
</head>
 <body>
 <div id="slicerContainer" style="border:1px solid gray;width:190px"></div>
     <hr/>
     <div id="list" style="width:300px;float:left"></div>
 </body>
 </html>

本示例创建一个自定义切片器,并使用 TableSlicerData 数据类。

<!DOCTYPE html>
<html>
<head>
 <title>SpreadJS Development Sample</title>
     <link href="./css/gc.spread.sheets.excel2013white.13.0.0.css" rel="stylesheet" type="text/css" />
    <script src="http://code.jquery.com/jquery-2.0.2.js" type="text/javascript"></script>
     <script src="./scripts/gc.spread.sheets.all.13.0.0.min.js"></script>
     <script type="text/javascript">
     //定义数据源
         data = [
         { "Name": "Bob", "City": "NewYork", "Birthday": "1968/6/8" },
         { "Name": "Bob", "City": "NewYork", "Birthday": "1968/6/8" },
         { "Name": "Bob", "City": "NewYork", "Birthday": "1968/6/8" },
         { "Name": "Bob", "City": "NewYork", "Birthday": "1968/6/8" },
         { "Name": "Betty", "City": "Washington", "Birthday": "1972/7/3" },
         { "Name": "Betty", "City": "Washington", "Birthday": "1972/7/3" },
         { "Name": "Betty", "City": "Washington", "Birthday": "1972/7/3" },
         { "Name": "Alice", "City": "NewYork", "Birthday": "1964/3/2" },
         { "Name": "Alice", "City": "NewYork", "Birthday": "1964/3/2" },
         { "Name": "Alice", "City": "NewYork", "Birthday": "1964/3/2" }];
    //自定义切片器
         function MySlicer(container) {
         this.container = container;
         this.slicerData = null;
         this.columnName = null;
     }
     MySlicer.prototype.setData = function (slicerData, columnName) {
         this.slicerData = slicerData;
         this.columnName = columnName;
         this.slicerData.attachListener(this);
         this.onDataLoaded();
     }
     MySlicer.prototype.onDataLoaded = function () {
         //创建切片器dom树。
             var columnName = this.columnName,
         exclusiveData = this.slicerData.getExclusiveData(columnName);
         $(this.container).append($('<span>' + this.columnName + ':</span>' + '<br />'));
         var domString = "";
         for (var i = 0; i < exclusiveData.length; i++) {
             domString += '<input type="checkbox" name="' + columnName + '" value="' + exclusiveData[i] + '">';
             domString += '<span>' + exclusiveData[i] + '</span>';
             domString += '<br />';
         }
         $(this.container).append($(domString));
         //将事件附加到dom。
             var self = this;
         $("[name='" + self.columnName + "']").change(function () {
             var slicer = self,
             exclusiveData = slicer.slicerData.getExclusiveData(slicer.columnName),
             parent = $(this).parent(),
             items = parent.children(),
             indexes = [];
             for (var i = 0, length = items.length; i < length; i++) {
                 if (items[i].checked) {
                     var value = items[i].value;
                     if (!isNaN(parseInt(value))) {
                         value = parseInt(value);
                     }
                     indexes.push(exclusiveData.indexOf(value))
                 }
             }
             if (indexes.length === 0) {
                 slicer.slicerData.doUnfilter(slicer.columnName);
             } else {
                 slicer.slicerData.doFilter(slicer.columnName, { exclusiveRowIndexes: indexes });
             }
         });
     };
     MySlicer.prototype.onFiltered = function () {
         //如果数据已被SpreadJS表筛选,则同步状态。
             var slicerdata = this.slicerData;
         var exclusiveIndexes = slicerdata.getFilteredIndexes(this.columnName);
         $.each($("#slicerContainer").children("input"), function (i,input) {
        });
     }
    $(document).ready(function () {            
         var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"),{sheetCount:1});
         var sheet = spread.getActiveSheet();
        //创建一个自定义切片器,然后将此切片器添加到“ slicerContainer” div中。
             var slicer = new MySlicer($("#slicerContainer")[0]);
         var table = sheet.tables.addFromDataSource("table1", 1, 1, data);
         var slicerData = table.getSlicerData();
         slicer.setData(slicerData, "Name");
    });
 </script>
</head>
 <body>
 <div id="slicerContainer" style="border:1px solid gray;width:190px"></div>
     <hr />
     <div id="ss" style="width:500px;height:500px;border:1px solid gray"></div>
 </body>
 </html>