In the previous section, we learned how to use Svelte to encapsulate the Web Component to use the spreadsheet Component across different pages.
The benefits of reusing Svelte packaged components across frameworks are also obvious:
1, the use of framework development, easier to maintain
2. No framework dependencies after release, any other scenarios can be used
3. Published Web Components are small
These unique advantages, make Svelte component packaging has a particular advantage. Earlier we saw how to freely use the spreadsheet component from page to page. So what if you wanted to actually use the same table component across different frameworks?
Let’s pick up where we left off and show you how to make the spreadsheet component usable across frameworks and native environments once you’ve wrapped it.
Cross framework component development
Develop AutoComplete Web Component using Svelte
Svelte’s ecosystem is now very rich, we can find a component of AutoComplete developed by Svelte by searching: github.com/pstanoev/si… .
Let’s fork the project, make some simple changes, and have it generate a Web Component.
1, modify SRC/SimpleAutocomplete. Svelte
In the header add:
<svelte:options tag="auto-complete" />
Copy the code
Also modify items in the code to add some default information:
// the list of items the user can select from
export let items = [];
items = ["White", "Red", "Yellow", "Green", "Blue", "Black"];
Copy the code
2. Modify rollup.config.js
Configure the customElement in plugins
The result is as follows:
import commonjs from '@rollup/plugin-commonjs';
import resolve from '@rollup/plugin-node-resolve';
import svelte from 'rollup-plugin-svelte';
import pkg from './package.json';
export default [
{
input: 'src/SimpleAutocomplete.svelte',
output: [
{ file: pkg.module, format: 'es' },
{ file: pkg.main, format: 'umd', name: 'Autocomplete' }
],
plugins: [svelte({
customElement: true,
}), commonjs(), resolve()]
}
];
Copy the code
3. Run NPM Run Build package to generate Web Component
Js and index. MJS will be generated in the root directory. Js is umD supported, MJS is ES version, and we will directly use umD supported index.js file.
Second, no frame page test
<div id="ss" style="height: 600px;" ></div> <script type="text/javascript" src="index.js"></script> <script type="text/javascript"> window.onload = function(){ var spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss")); var sheet = spread.getActiveSheet(); sheet.setCellType(1, 1, new AutoComplateCellType()) } function AutoComplateCellType() { } AutoComplateCellType.prototype = new GC.Spread.Sheets.CellTypes.Base(); AutoComplateCellType.prototype.createEditorElement = function () { var ac = document.createElement('auto-complete'); ac.setAttribute("gcUIElement", "gcEditingInput"); return ac; } AutoComplateCellType.prototype.updateEditor = function(editorContext, cellStyle, cellRect) { if (editorContext) { editorContext.style.width=cellRect.width; editorContext.style.height=32; editorContext.parentElement.parentElement.style.overflow = "visible"; return {height: 32}; }}; AutoComplateCellType.prototype.getEditorValue = function (editorContext) { if (editorContext) { return editorContext.value; }}; AutoComplateCellType.prototype.setEditorValue = function (editorContext, value) { if (editorContext) { editorContext.value = value } }; </script>Copy the code
Create AutoComplateCellType with index.js and set it to singleton.
Import AutoComplate Web Component from Vue framework
<script> import '@grapecity/spread-sheets-vue' import '.. Import * as GC from "@grapecity/spread-sheets" function AutoComplateCellType() { } AutoComplateCellType.prototype = new GC.Spread.Sheets.CellTypes.Base(); AutoComplateCellType.prototype.createEditorElement = function () { var ac = document.createElement('auto-complete'); ac.setAttribute("gcUIElement", "gcEditingInput"); return ac; } AutoComplateCellType.prototype.updateEditor = function(editorContext, cellStyle, cellRect) { if (editorContext) { editorContext.style.width=cellRect.width; editorContext.style.height=32; editorContext.parentElement.parentElement.style.overflow = "visible"; return {height: 32}; }}; AutoComplateCellType.prototype.getEditorValue = function (editorContext) { if (editorContext) { return editorContext.value; }}; AutoComplateCellType.prototype.setEditorValue = function (editorContext, value) { if (editorContext) { editorContext.value = value } }; export default { // name: 'sample-header' methods:{ workbookInitialized(spread){ var sheet = spread.getActiveSheet(); sheet.setCellType(1, 1, new AutoComplateCellType()) } } } </script>Copy the code
Here pay attention to the packaging of the index, js will quote after introducing a bug on the TS, delete files in the following content.
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
React works the same way, so I won’t repeat it here.
If you have other ideas, implementation ideas, also welcome to comment exchange.