利用 Angular CLI 创建基于 SpreadJS 的电子表格应用
本帖最后由 AlexZ 于 2020-8-23 23:46 编辑Angular CLI(命令行界面)是Angular开发人员工具箱中最受欢迎的功能之一,它可以自动解决Angular开发所带来的许多挑战,从而使入门变得更加容易。SpreadJS可以与Angular一起使用,因此,很自然的是,开发人员可能希望在Angular CLI中使用它。
本教程介绍了如何使用SpreadJS自动创建简单的Angular电子表格应用程序。
设置Angular电子表格
本教程将重点介绍使用命令提示符,因此请继续打开它。
Angular CLI必须在全局安装,这可以通过以下命令完成:
npm install -g @angular/cli 安装后,您可以使用Angular CLI创建一个新项目。在这种情况下,我们将项目称为“ spreadjs-angular-app”。在命令提示符下,导航到希望应用程序运行的位置,然后键入以下命令:
ng new spreadjs-angular-app
这将创建一个目录,其中包含运行Angular应用程序所需的所有文件。要添加SpreadJS,我们可以简单地从NPM获取文件,方法是运行以下命令以在项目目录中安装SJS文件:
npm install @grapecity/spread-sheets @grapecity/spread-sheets-angular 安装文件后,我们需要让应用程序知道它们的位置。要编辑的第一个文件是项目根目录中的“ angular.json”文件。
添加“样式”和“脚本”属性:
{
...
"projects": {
"spread-sheets-app": {
...
"architect": {
"build": {
...
"options": {
...
"styles": [
"src/styles.css",
"node_modules/@grapecity/spread-sheets/styles/gc.spread.sheets.excel2013white.css"
],
"scripts": [
"node_modules/@grapecity/spread-sheets/dist/gc.spread.sheets.all.min.js"
]
},
...
}
}
}
},
...
}
添加指向“ tsconfig.app.json”文件中文件的链接:
{
...
"files: [
...
"./node_modules/@grapecity/spread-sheets-angular/dist/gc.spread.sheets.angular.ts",
"./node_modules/@grapecity/spread-sheets/dist/gc.spread.sheets.d.ts"
],
...
}设置的最后一部分是将SpreadJS Angular电子表格组件添加到“ src> app> app.module.ts”文件中:
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { SpreadSheetsModule } from '@grapecity/spread-sheets-angular/dist/gc.spread.sheets.angular';
import { AppRoutingModule } from './app-routing.module';
import { AppComponent } from './app.component';
@NgModule({
declarations: [
AppComponent
],
imports: [
BrowserModule,
SpreadSheetsModule,
AppRoutingModule
],
providers: [],
bootstrap:
})
export class AppModule { }为Angular Spreadsheet应用程序添加HTML和JavaScript代码
在与“ app.module.ts”文件相同的文件夹中,我们可以修改“ app.component.html”文件以显示SpreadJS组件:
<gc-spread-sheets ="spreadBackColor" ="hostStyle">
<gc-worksheet ="sheetName" ="data" ="rowOutlineInfo">
<gc-column dataField="name" headerText="Name" width=310></gc-column>
<gc-column dataField="chapter" headerText="Chapter" width=150></gc-column>
<gc-column dataField="page" headerText="Page" width=150></gc-column>
</gc-worksheet>
</gc-spread-sheets>上面代码中的不同属性将在脚本代码中定义。在这种情况下,脚本将被添加到同一文件夹中的“ app.component.ts”文件中。我们可以从初始化一些初始变量的组件以及我们的SJS许可开始:
import { Component } from '@angular/core';
import * as GC from "@grapecity/spread-sheets";
GC.Spread.Sheets.LicenseKey = "<YOUR LICENSE HERE>";
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.css']
})
export class AppComponent {
title = 'spreadjs-angular-app';
spreadBackColor = 'aliceblue';
sheetName = 'Java 101 Chapters';
hostStyle = {
width: '800px',
height: '600px'
};
data: any;
rowOutlineInfo: any;
showRowOutline = true;
}由于我们要绑定到数据,因此可以向AppComponent类添加一个构造函数以初始化该数据:
constructor() {
// This is the base data that we will bind to the Spread instance
let commands = [
{ name: 'Preface', chapter: '1', page: 1, indent: 0 },
{ name: 'Java SE5 and SE6', chapter: '1.1', page: 2, indent: 1 },
{ name: 'Java SE6', chapter: '1.1.1', page: 2, indent: 2 },
{ name: 'The 4th edition', chapter: '1.2', page: 2, indent: 1 },
{ name: 'Changes', chapter: '1.2.1', page: 3, indent: 2 },
{ name: 'Note on the cover design', chapter: '1.3', page: 4, indent: 1 },
{ name: 'Acknowledgements', chapter: '1.4', page: 4, indent: 1 },
{ name: 'Introduction', chapter: '2', page: 9, indent: 0 },
{ name: 'Prerequisites', chapter: '2.1', page: 9, indent: 1 },
{ name: 'Learning Java', chapter: '2.2', page: 10, indent: 1 },
{ name: 'Goals', chapter: '2.3', page: 10, indent: 1 },
{ name: 'Teaching from this book', chapter: '2.4', page: 11, indent: 1 },
{ name: 'JDK HTML documentation', chapter: '2.5', page: 11, indent: 1 },
{ name: 'Exercises', chapter: '2.6', page: 12, indent: 1 },
{ name: 'Foundations for Java', chapter: '2.7', page: 12, indent: 1 },
{ name: 'Source code', chapter: '2.8', page: 12, indent: 1 },
{ name: 'Coding standards', chapter: '2.8.1', page: 14, indent: 2 },
{ name: 'Errors', chapter: '2.9', page: 14, indent: 1 },
{ name: 'Introduction to Objects', chapter: '3', page: 15, indent: 0 },
{ name: 'The progress of abstraction', chapter: '3.1', page: 15, indent: 1 },
{ name: 'An object has an interface', chapter: '3.2', page: 17, indent: 1 },
{ name: 'An object provides services', chapter: '3.3', page: 18, indent: 1 },
{ name: 'The hidden implementation', chapter: '3.4', page: 19, indent: 1 },
{ name: 'Reusing the implementation', chapter: '3.5', page: 20, indent: 1 },
{ name: 'Inheritance', chapter: '3.6', page: 21, indent: 1 },
{ name: 'Is-a vs. is-like-a relationships', chapter: '3.6.1', page: 24, indent: 2 },
{ name: 'Interchangeable objects with polymorphism', chapter: '3.7', page: 25, indent: 1 },
{ name: 'The singly rooted hierarchy', chapter: '3.8', page: 28, indent: 1 },
{ name: 'Containers', chapter: '3.9', page: 28, indent: 1 },
{ name: 'Parameterized types (Generics)', chapter: '3.10', page: 29, indent: 1 },
{ name: 'Object creation & lifetime', chapter: '3.11', page: 30, indent: 1 },
{ name: 'Exception handling: dealing with errors', chapter: '3.12', page: 31, indent: 1 },
{ name: 'Concurrent programming', chapter: '3.13', page: 32, indent: 1 },
{ name: 'Java and the Internet', chapter: '3.14', page: 33, indent: 1 },
{ name: 'What is the Web?', chapter: '3.14.1', page: 33, indent: 2 },
{ name: 'Client-side programming', chapter: '3.14.2', page: 34, indent: 2 },
{ name: 'Server-side programming', chapter: '3.14.3', page: 38, indent: 2 },
{ name: 'Summary', chapter: '3.15', page: 38, indent: 1 },
{ name: 'End', chapter: '', indent: null }
];
}此特定数据将使用行概述,因此我们可以向该构造函数添加代码以为数据源中的每一行创建行轮廓。以下逻辑将基于每个数据行的“缩进”值创建行轮廓,并将它们缩进指定的空格量:// Create a rowOutlineInfo object for each row
this.rowOutlineInfo = [];
for (let r = 0; r < commands.length; r++) {
var subRows = 0;
// Get the number of rows that subrows to the current one and add them to the outline
for (let r2 = r + 1; r2 < commands.length; r2++) {
if (commands.indent > commands.indent) {
subRows++;
}
if ((r2 == (commands.length - 1)) || (commands.indent == commands.indent)) {
var i = { index: r + 1, count: subRows }
this.rowOutlineInfo.push(i);
break;
}
}
// Add tabs based on the indent column
for (let i = 0; i < commands.indent; i++) {
commands.name = "\t\t\t\t\t" + commands.name;
}
}
最后,我们可以为Spread实例设置数据:
// Set the data for Spread
this.data = commands;建立并运行您的Angular电子表格
该应用程序的代码已完成,因此现在我们只需要构建和运行它即可。为此,我们可以简单地返回命令提示符并输入以下命令:
ng serve
成功构建应用程序后,可以通过导航到“ localhost:4200”在浏览器中查看JavaScript Excel电子表格:
SpreadJS可以与许多不同的框架一起使用,而Angular只是其中之一。Angular CLI使创建应用程序变得容易,而SpreadJS使显示数据更加容易。
页:
[1]