Angular 7が2018年10月に正式リリースされ、仮想スクロール、ドラッグ&ドロップCDK、パフォーマンス改善などの重要な改良が加わりました。注目すべき新機能をまとめます。
仮想スクロール Virtual Scrolling
@angular/cdk/scrollingが提供する仮想スクロールは、表示領域のリストアイテムのみをレンダリングし、大きなリストのパフォーマンスを大幅に向上させます:
typescript
{% raw %}
import { ScrollingModule } from '@angular/cdk/scrolling';
@Component({
template: `
<cdk-virtual-scroll-viewport itemSize="50" style="height: 400px">
<div *cdkVirtualFor="let item of items">{{ item }}</div>
</cdk-virtual-scroll-viewport>
`
})
export class AppComponent {
items = Array.from({ length: 10000 }, (_, i) => `Item #${i}`);
}
{% endraw %}
ドラッグ&ドロップ CDK DragDrop
typescript
{% raw %}
import { DragDropModule } from '@angular/cdk/drag-drop';
@Component({
template: `
<div cdkDropList (cdkDropListDropped)="drop($event)">
<div *ngFor="let item of items" cdkDrag>{{ item }}</div>
</div>
`
})
export class DragListComponent {
items = ['Apple', 'Banana', 'Cherry'];
drop(event: CdkDragDrop<string[]>) {
moveItemInArray(this.items, event.previousIndex, event.currentIndex);
}
}
{% endraw %}
パフォーマンス改善
- アプリのバンドルサイズが平均30〜40%削減
- CLIのヒントとエラーメッセージがより分かりやすく
- 依存関係のアップグレード:TypeScript 3.1+、RxJS 6.3+
まとめ
Angular 7は安定したアップデートで、仮想スクロールとドラッグ&ドロップCDKがすぐに使えるハイライトです。大規模企業アプリに適しています。