Я использую ag-grid уже пару месяцев.Сегодня я попытался интегрировать сетку, которую я успешно построил в предыдущем проекте, в этот шаблон Angular:
ngx-admin Вот как выглядит шаблон:
![enter image description here](https://i.stack.imgur.com/Mfjw8.png)
Я попытался добавить еще одну страницу внутри дополнительных компонентов, которая содержала бы сетку:
Но, как вы видите, шаблон не обрабатывается.
Это папка с дополнительными компонентами внутри проекта:
![enter image description here](https://i.stack.imgur.com/EPi33.png)
action-plan.component.html
<!-- I have tested this with a normal Angular project and it worked perfectly -->
ahmed
<ag-grid-angular
style="width: 100% ; height: 1000px;"
[rowData]="actionPlanPartiesrowData"
[columnDefs]="actionPlanPartiescolumnDefs"
(gridReady)="actionPlanPartiesonGridReady($event)"
[getRowHeight]="getRowHeight"
[animateRows]="true"
[defaultColDef]="defaultColDef"
(cellValueChanged)="onactionPlanPartiesCellValueChanged($event)"
>
</ag-grid-angular>
action-plan.component.ts
import { Component, OnInit } from "@angular/core";
@Component({
selector: "app-action-plan",
templateUrl: "./action-plan.component.html",
styleUrls: ["./action-plan.component.css"]
})
export class ActionPlanComponent implements OnInit {
private actionPlangridApi;
actionPlanPartiescolumnDefs = [
{
headerName: "Id",
field: "id",
editable: true,
width: 100
},
{
headerName: "Project",
field: "project",
editable: true,
width: 400
},
{
headerName: "Risk ID",
field: "riskId",
editable: true,
width: 300
},
{
headerName: "ISO 27001",
field: "iso27001",
editable: true,
width: 150
},
{
headerName: "Priority",
field: "priority",
editable: true,
width: 150
},
{
headerName: "Project Owner",
field: "projectOwner",
editable: true,
width: 150
},
{
headerName: "Estimated Cost",
field: "estimatedCost",
editable: true,
width: 150
}
];
actionPlanPartiesrowData = [{}, {}, {}, {}, {}, {}, {}, {}, {}, {}];
defaultColDef = {
sortable: true,
resizable: true,
filter: true
};
ngOnInit() {}
constructor() {}
actionPlanPartiesonGridReady(params) {
}
onactionPlanPartiesCellValueChanged(params) {
}
public getRowHeight(params) {
return 130;
}
}
extra-components.module.ts
import { NgModule } from '@angular/core';
import { TreeModule } from 'angular-tree-component';
import { ToasterModule } from 'angular2-toaster';
import { ThemeModule } from '../../@theme/theme.module';
import { ExtraComponentsRoutingModule } from './extra-components-routing.module';
// components
import { ExtraComponentsComponent } from './extra-components.component';
import { TreeComponent } from './tree/tree.component';
import { SpinnerInTabsComponent } from './spinner/spinner-in-tabs/spinner-in-tabs.component';
import { SpinnerInButtonsComponent } from './spinner/spinner-in-buttons/spinner-in-buttons.component';
import { SpinnerSizesComponent } from './spinner/spinner-sizes/spinner-sizes.component';
import { SpinnerColorComponent } from './spinner/spinner-color/spinner-color.component';
import { SpinnerComponent } from './spinner/spinner.component';
import {
InteractiveProgressBarComponent,
} from './progress-bar/interactive-progress-bar/interactive-progress-bar.component';
import { ProgressBarComponent } from './progress-bar/progress-bar.component';
import { AlertComponent } from './alert/alert.component';
import { ChatComponent } from './chat/chat.component';
import { Tab1Component, Tab2Component, TabsComponent } from './tabs/tabs.component';
import { CalendarComponent } from './calendar/calendar.component';
import { DayCellComponent } from './calendar/day-cell/day-cell.component';
import { StepperComponent } from './stepper/stepper.component';
import { ListComponent } from './list/list.component';
import { InfiniteListComponent } from './infinite-list/infinite-list.component';
import { NewsPostComponent } from './infinite-list/news-post/news-post.component';
import { NewsPostPlaceholderComponent } from './infinite-list/news-post-placeholder/news-post-placeholder.component';
import { AccordionComponent } from './accordion/accordion.component';
import { NebularFormInputsComponent } from './form-inputs/nebular-form-inputs.component';
import { NebularSelectComponent } from './form-inputs/nebular-select/nebular-select.component';
import { CalendarKitFullCalendarShowcaseComponent } from './calendar-kit/calendar-kit.component';
import { CalendarKitMonthCellComponent } from './calendar-kit/month-cell/month-cell.component';
// service
import { NewsService } from './services/news.service';
import { ActionPlanComponent } from './ahmed/action-plan.component';
import { AgGridModule } from 'ag-grid-angular';
const COMPONENTS = [
ExtraComponentsComponent,
TreeComponent,
AlertComponent,
ProgressBarComponent,
InteractiveProgressBarComponent,
SpinnerComponent,
SpinnerColorComponent,
SpinnerSizesComponent,
SpinnerInButtonsComponent,
SpinnerInTabsComponent,
CalendarComponent,
DayCellComponent,
ChatComponent,
TabsComponent,
Tab1Component,
Tab2Component,
StepperComponent,
ListComponent,
InfiniteListComponent,
NewsPostComponent,
NewsPostPlaceholderComponent,
AccordionComponent,
NebularFormInputsComponent,
NebularSelectComponent,
CalendarKitFullCalendarShowcaseComponent,
CalendarKitMonthCellComponent,
ActionPlanComponent
];
const SERVICES = [
NewsService,
];
const MODULES = [
];
@NgModule({
imports: [
ThemeModule,
ExtraComponentsRoutingModule,
TreeModule,
ToasterModule.forRoot(),
AgGridModule.withComponents([
])
],
declarations: [
...COMPONENTS,
],
providers: [
...SERVICES,
],
})
export class ExtraComponentsModule { }
У других естьстолкнулся с той же проблемой, что и я, но решение предоставлено путем импорта ag-grid-angular в app.module.ts, что я и сделал.Но это не решило проблему.(в моем случае extra-components.module.ts) В проекте есть другие файлы module.ts в папках более высокого уровня, в которые я также импортировал модуль ag-grid-angular на всякий случай:
Вот что появляется в VSCode:
«ag-grid-angular» не является известным элементом: 1. Если «ag-grid-angular» является угловым компонентом, то убедитесь, чтоэто часть этого модуля.2. Если «ag-grid-angular» является веб-компонентом, то добавьте «CUSTOM_ELEMENTS_SCHEMA» в «@ NgModule.schemas» этого компонента, чтобы подавить это сообщение.известное свойство «ag-grid-angular».1. Если «ag-grid-angular» является угловым компонентом и имеет вход «getRowHeight», то убедитесь, что он является частью этого модуля.2. Если 'ag-grid-angular' является веб-компонентом, то добавьте 'CUSTOM_ELEMENTS_SCHEMA' к '@ NgModule.schemas' этого компонента, чтобы подавить это сообщение.3. Чтобы разрешить любое свойство, добавьте «NO_ERRORS_SCHEMA» к «@ NgModule.schemas» этого компонента. Angular