最初の実装後、ターミナルng serve my-appに入力した後、何千ものこのエラーが発生し、解決できません。 TypeScriptエラーのあるangularの内部でこのような問題が発生したのは、今回が初めてです。
../../node_modules/@angular/flex-layout/core/typings/base/base2.d.ts:24:19のエラー-エラーTS1086:アンサーコンテキストでアクセサーを宣言できません。
24 protected get parentElement(): HTMLElement | null; ~~~~~~~~~~~~~ ../../node_modules/@angular/flex-layout/core/typings/base/base2.d.ts:26:19
-エラーTS1086:アンビエントコンテキストではアクセサーを宣言できません。
26 protected get nativeElement(): HTMLElement; ~~~~~~~~~~~~~ ../../node_modules/@angular/flex-layout/core/typings/base/base2.d.ts:28:9
-エラーTS1086:アンビエントコンテキストではアクセサーを宣言できません。
28 get activatedValue(): string; ~~~~~~~~~~~~~~ ../../node_modules/@angular/flex-layout/core/typings/base/base2.d.ts:29:9
-エラーTS1086:アンビエントコンテキストではアクセサーを宣言できません。
29 set activatedValue(value: string); ~~~~~~~~~~~~~~ ../../node_modules/@angular/flex-layout/core/typings/breakpoints/break-point-registry.d.ts:20:9
-エラーTS1086:アンビエントコンテキストではアクセサーを宣言できません。
[...]
誰かが理由を知っていますか?修正するまでアプリをテストできません。
さて、私はそれを前進させます。エラーのほとんどはなくなりましたが、今はいくつかあります。たとえば、最初のエラーです。
Src/app/main/main.component.ts:143:63のエラー-エラーTS2322:タイプ 'string | undefinedはタイプ 'string'に割り当てることができません。タイプ「未定義」はタイプ「文字列」に割り当てることができません。
143 this.fileService.add({isFolder:true、name:folder.name、parent:this.currentRoot?this.currentRoot.id: 'root'});
コードは次のようになります。
main.component.ts:
currentRoot: MpFileElement = new MpFileElement();
...
addFolder(folder: { name: string }) {
this.fileService.add({ isFolder: true, name: folder.name, parent:
this.currentRoot ? this.currentRoot.id : 'root' });
this.updateFileElementQuery();
}
...
file.service.ts:
import { Injectable } from '@angular/core';
import { v4 } from 'uuid';
import { MpFileElement } from '../models/mp-file-element.model';
import { Observable } from 'rxjs/internal/Observable';
import { BehaviorSubject } from 'rxjs';
export interface IFileService {
add(fileElement: MpFileElement);
delete(id: string);
update(id: string, update: Partial<MpFileElement>);
queryInFolder(folderId: string): Observable<MpFileElement[]>;
get(id: string): MpFileElement;
}
@Injectable()
export class MpFileService implements IFileService {
constructor() {}
private map = new Map<string, MpFileElement>()
private querySubject: BehaviorSubject<MpFileElement[]>;
add(fileElement: MpFileElement) {
fileElement.id = v4();
this.map.set(fileElement.id, this.clone(fileElement));
return fileElement;
}
delete(id: string) {
this.map.delete(id);
}
update(id: string, update: Partial<MpFileElement>) {
let element = this.map.get(id);
element = Object.assign(element, update);
this.map.set(element.id, element);
}
queryInFolder(folderId: string) {
const result: MpFileElement[] = [];
this.map.forEach(element => {
if (element.parent === folderId) {
result.Push(this.clone(element));
}
})
if (!this.querySubject) {
this.querySubject = new BehaviorSubject(result);
} else {
this.querySubject.next(result);
}
return this.querySubject.asObservable();
}
get(id: string) {
return this.map.get(id);
}
clone(element: MpFileElement) {
return JSON.parse(JSON.stringify(element));
}
}
私は新しいプロジェクトに取り組んでいて、同様の問題を抱えていました。私はただ走ったng update --all
そして私の問題は解決されました。
私の場合、2つのライブラリのバージョンの不一致です。
angular 7.0.を使用してインストールしています
"@swimlane/ngx-dnd": "^8.0.0"
これが問題の原因です。このライブラリを元に戻す
"@swimlane/ngx-dnd": "6.0.0"
私のために働いた。