Cell Merging

FlexSheet supports merging the selected cells into one by invoking the mergeRange method. If the selected cells contain merged cells, the mergeRange method will un-merge the merged cells. Otherwise, it will merge the selected cells into one cell. FlexSheet allows merging of cells that contain any data. This is different from FlexGrid, which supports content-driven cell merging.

Learn about FlexSheet | FlexSheet API Reference

app.js
index.html
styles.css
Copy to CodeMine
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import * as wjFlexSheet from '@mescius/wijmo.grid.sheet'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { let mergeSheet = new wjFlexSheet.FlexSheet('#mergeSheet'); mergeSheet.addUnboundSheet('unbound', 20, 8); mergeSheet.deferUpdate(() => { let colIdx, rowIdx; for (colIdx = 0; colIdx < mergeSheet.columns.length; colIdx++) { for (rowIdx = 0; rowIdx < mergeSheet.rows.length; rowIdx++) { mergeSheet.setCellData(rowIdx, colIdx, colIdx + rowIdx); } } }); updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); mergeSheet.selectionChanged.addHandler(() => { updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); }); document.querySelector('#mergeButton').addEventListener('click', () => { mergeSheet.mergeRange(); updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); }); function updateMergeButtonState(isMergeCell) { let mergeButton = document.querySelector('#mergeButton'); if (isMergeCell) { mergeButton.textContent = 'UnMerge'; } else { mergeButton.textContent = 'Merge'; } } }
import 'bootstrap.css'; import '@mescius/wijmo.styles/wijmo.css'; import './styles.css'; import * as wjFlexSheet from '@mescius/wijmo.grid.sheet'; // document.readyState === 'complete' ? init() : window.onload = init; // function init() { let mergeSheet = new wjFlexSheet.FlexSheet('#mergeSheet'); mergeSheet.addUnboundSheet('unbound', 20, 8); mergeSheet.deferUpdate(() => { let colIdx, rowIdx; for (colIdx = 0; colIdx < mergeSheet.columns.length; colIdx++) { for (rowIdx = 0; rowIdx < mergeSheet.rows.length; rowIdx++) { mergeSheet.setCellData(rowIdx, colIdx, colIdx + rowIdx); } } }); updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); mergeSheet.selectionChanged.addHandler(() => { updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); }); document.querySelector('#mergeButton').addEventListener('click', () => { mergeSheet.mergeRange(); updateMergeButtonState(mergeSheet.getSelectionFormatState().isMergedCell); }); function updateMergeButtonState(isMergeCell) { let mergeButton = document.querySelector('#mergeButton'); if (isMergeCell) { mergeButton.textContent = 'UnMerge'; } else { mergeButton.textContent = 'Merge'; } } }
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <title>MESCIUS Wijmo FlexSheet Cell Merging</title> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <!-- SystemJS --> <script src="https://cdnjs.cloudflare.com/ajax/libs/systemjs/0.21.5/system.src.js" integrity="sha512-skZbMyvYdNoZfLmiGn5ii6KmklM82rYX2uWctBhzaXPxJgiv4XBwJnFGr5k8s+6tE1pcR1nuTKghozJHyzMcoA==" crossorigin="anonymous"></script> <script src="systemjs.config.js"></script> <script> System.import('./src/app'); </script> </head> <body> <div class="container-fluid"> <div id="mergeSheet"></div> <button id="mergeButton" type="button" class="btn btn-default"></button> </div> </body> </html>
.wj-flexsheet { height: 400px; margin: 6px 0; }
(function (global) { System.config({ transpiler: 'plugin-babel', babelOptions: { es2015: true }, meta: { '*.css': { loader: 'css' } }, paths: { // paths serve as alias 'npm:': 'node_modules/' }, // map tells the System loader where to look for things map: { 'jszip': 'npm:jszip/dist/jszip.js', '@mescius/wijmo': 'npm:@mescius/wijmo/index.js', '@mescius/wijmo.input': 'npm:@mescius/wijmo.input/index.js', '@mescius/wijmo.styles': 'npm:@mescius/wijmo.styles', '@mescius/wijmo.cultures': 'npm:@mescius/wijmo.cultures', '@mescius/wijmo.chart': 'npm:@mescius/wijmo.chart/index.js', '@mescius/wijmo.chart.analytics': 'npm:@mescius/wijmo.chart.analytics/index.js', '@mescius/wijmo.chart.animation': 'npm:@mescius/wijmo.chart.animation/index.js', '@mescius/wijmo.chart.annotation': 'npm:@mescius/wijmo.chart.annotation/index.js', '@mescius/wijmo.chart.finance': 'npm:@mescius/wijmo.chart.finance/index.js', '@mescius/wijmo.chart.finance.analytics': 'npm:@mescius/wijmo.chart.finance.analytics/index.js', '@mescius/wijmo.chart.hierarchical': 'npm:@mescius/wijmo.chart.hierarchical/index.js', '@mescius/wijmo.chart.interaction': 'npm:@mescius/wijmo.chart.interaction/index.js', '@mescius/wijmo.chart.radar': 'npm:@mescius/wijmo.chart.radar/index.js', '@mescius/wijmo.chart.render': 'npm:@mescius/wijmo.chart.render/index.js', '@mescius/wijmo.chart.webgl': 'npm:@mescius/wijmo.chart.webgl/index.js', '@mescius/wijmo.chart.map': 'npm:@mescius/wijmo.chart.map/index.js', '@mescius/wijmo.gauge': 'npm:@mescius/wijmo.gauge/index.js', '@mescius/wijmo.grid': 'npm:@mescius/wijmo.grid/index.js', '@mescius/wijmo.grid.detail': 'npm:@mescius/wijmo.grid.detail/index.js', '@mescius/wijmo.grid.filter': 'npm:@mescius/wijmo.grid.filter/index.js', '@mescius/wijmo.grid.search': 'npm:@mescius/wijmo.grid.search/index.js', '@mescius/wijmo.grid.style': 'npm:@mescius/wijmo.grid.style/index.js', '@mescius/wijmo.grid.grouppanel': 'npm:@mescius/wijmo.grid.grouppanel/index.js', '@mescius/wijmo.grid.multirow': 'npm:@mescius/wijmo.grid.multirow/index.js', '@mescius/wijmo.grid.transposed': 'npm:@mescius/wijmo.grid.transposed/index.js', '@mescius/wijmo.grid.transposedmultirow': 'npm:@mescius/wijmo.grid.transposedmultirow/index.js', '@mescius/wijmo.grid.pdf': 'npm:@mescius/wijmo.grid.pdf/index.js', '@mescius/wijmo.grid.sheet': 'npm:@mescius/wijmo.grid.sheet/index.js', '@mescius/wijmo.grid.xlsx': 'npm:@mescius/wijmo.grid.xlsx/index.js', '@mescius/wijmo.grid.selector': 'npm:@mescius/wijmo.grid.selector/index.js', '@mescius/wijmo.grid.cellmaker': 'npm:@mescius/wijmo.grid.cellmaker/index.js', '@mescius/wijmo.nav': 'npm:@mescius/wijmo.nav/index.js', '@mescius/wijmo.odata': 'npm:@mescius/wijmo.odata/index.js', '@mescius/wijmo.olap': 'npm:@mescius/wijmo.olap/index.js', '@mescius/wijmo.rest': 'npm:@mescius/wijmo.rest/index.js', '@mescius/wijmo.pdf': 'npm:@mescius/wijmo.pdf/index.js', '@mescius/wijmo.pdf.security': 'npm:@mescius/wijmo.pdf.security/index.js', '@mescius/wijmo.viewer': 'npm:@mescius/wijmo.viewer/index.js', '@mescius/wijmo.xlsx': 'npm:@mescius/wijmo.xlsx/index.js', '@mescius/wijmo.undo': 'npm:@mescius/wijmo.undo/index.js', '@mescius/wijmo.interop.grid': 'npm:@mescius/wijmo.interop.grid/index.js', '@mescius/wijmo.touch': 'npm:@mescius/wijmo.touch/index.js', '@mescius/wijmo.cloud': 'npm:@mescius/wijmo.cloud/index.js', '@mescius/wijmo.barcode': 'npm:@mescius/wijmo.barcode/index.js', '@mescius/wijmo.barcode.common': 'npm:@mescius/wijmo.barcode.common/index.js', '@mescius/wijmo.barcode.composite': 'npm:@mescius/wijmo.barcode.composite/index.js', '@mescius/wijmo.barcode.specialized': 'npm:@mescius/wijmo.barcode.specialized/index.js', 'jszip': 'npm:jszip/dist/jszip.js', 'bootstrap.css': 'npm:bootstrap/dist/css/bootstrap.min.css', 'css': 'npm:systemjs-plugin-css/css.js', 'plugin-babel': 'npm:systemjs-plugin-babel/plugin-babel.js', 'systemjs-babel-build':'npm:systemjs-plugin-babel/systemjs-babel-browser.js' }, // packages tells the System loader how to load when no filename and/or no extension packages: { src: { defaultExtension: 'js' }, "node_modules": { defaultExtension: 'js' }, } }); })(this);