Diskussionsthread zur Schulung #1
Replies: 28 comments 3 replies
-
<div class="container">
<h1>
<img
width="100"
alt="Angular Logo"
src=""
/>
{{ title }}
</h1>
<!-- <router-outlet></router-outlet> -->
</div> |
Beta Was this translation helpful? Give feedback.
-
npm install --location=global @angular/cli@latest ng version
|
Beta Was this translation helpful? Give feedback.
-
|
Beta Was this translation helpful? Give feedback.
-
|
Beta Was this translation helpful? Give feedback.
-
Beta Was this translation helpful? Give feedback.
-
"lokale AI" mit Ollama und VSCode-Extension
|
Beta Was this translation helpful? Give feedback.
-
Hausaufgaben
|
Beta Was this translation helpful? Give feedback.
-
<div class="card mb-4">
<div class="card-body bg-light">
<img class="img-thumbnail float-end" alt=""
src="https://api.angular.schule/avatar/{{ book().rating }}">
<div class="card-title">
<h2>
{{ book().title }}
<span class="badge bg-secondary">{{ book().rating }}</span>
</h2>
</div>
<p>{{ book().description }}</p>
</div>
</div> |
Beta Was this translation helpful? Give feedback.
-
![]() |
Beta Was this translation helpful? Give feedback.
-
describe('In der Mathematik', () => {
let summand: number;
beforeEach(() => {
// Arrange
summand = 1;
});
it('soll 1 + 1 immer 2', () => {
// Act
const result = summand + 1;
// Assert
expect(result).toBe(2)
});
}); |
Beta Was this translation helpful? Give feedback.
-
|
Beta Was this translation helpful? Give feedback.
-
Doch wieder "Service" ^^
|
Beta Was this translation helpful? Give feedback.
-
Test import { Book } from './book';
import { BookRatingService } from './book-rating.service';
fdescribe('BookRatingService', () => {
let service: BookRatingService;
let book: Book;
beforeEach(() => {
service = new BookRatingService();
book = {
isbn: 'test',
title: 'Test',
description: 'Test',
rating: 3
};
});
it('should rate up a book by one', () => {
const ratedBook = service.rateUp(book);
expect(ratedBook.rating).toBe(4);
});
it('should rate down a book by one', () => {
const ratedBook = service.rateDown(book);
expect(ratedBook.rating).toBe(2);
});
it('should not be allowed to have a rating greater than 5', () => {
book.rating = 5;
const ratedBook = service.rateUp(book);
expect(ratedBook.rating).toBe(5);
});
it('should not be allowed to have a rating smaller than 1', () => {
book.rating = 1;
const ratedBook = service.rateDown(book);
expect(ratedBook.rating).toBe(1);
});
it('should not mutate the book', () => {
const frozenBook = Object.freeze(book);
expect(() => service.rateUp(frozenBook)).not.toThrow();
expect(() => service.rateDown(frozenBook)).not.toThrow();
});
}); Service: import { Injectable } from '@angular/core';
import { Book } from './book';
@Injectable({
providedIn: 'root'
})
export class BookRatingService {
rateUp(book: Book): Book {
return book; // TODO: implementation
}
rateDown(book: Book): Book {
return book; // TODO: implementation
}
} |
Beta Was this translation helpful? Give feedback.
-
Hausaufgabea) Teste die Oberfläche mit einem e2e Tool ( ODER b) Teste einen weitere Aspekt der Software (mit einem LLM). |
Beta Was this translation helpful? Give feedback.
-
https://refactoring.guru/design-patterns
|
Beta Was this translation helpful? Give feedback.
-
Hands on!Durch die Logik im Template der Option:
|
Beta Was this translation helpful? Give feedback.
-
<form>
<div class="form-group">
<label for="isbn">ISBN</label>
<input type="text" class="form-control" id="isbn">
@if (false) {
<div class="feedback-error">The ISBN is not valid!</div>
}
</div>
<div class="form-group">
<label for="title">Title</label>
<input type="text" class="form-control" id="title">
</div>
<div class="form-group">
<label for="description">Description</label>
<textarea class="form-control" id="description"></textarea>
</div>
<button
type="submit" class="btn btn-primary mb-4">Create</button>
</form> |
Beta Was this translation helpful? Give feedback.
-
🎮 NEU: RxJS PlaygroundDu kannst dir entweder
cd rxjs-playground
npm install
ng serve Öffne den Browser unter der URL http://localhost:4300 (!), um die Anwendung zu sehen. |
Beta Was this translation helpful? Give feedback.
-
|
Beta Was this translation helpful? Give feedback.
-
Miss the old angular.io/resources? We brought it back!The old list of valuable resources from angular.io is gone. Here you can find a mirror. |
Beta Was this translation helpful? Give feedback.
-
Generating Angular API clients with OpenAPI GeneratorIn this article, we'll show how to use OpenAPI Generator to automatically generate Angular HTTP services from your OpenAPI spec. https://angular.schule/blog/2025-06-openapi-generator Beispiel im Übungsprojekt: https://github.com/angular-schule/2025-06-angular-workshop-muenchen/tree/openapi-generator-playground |
Beta Was this translation helpful? Give feedback.
-
LLM prompts and AI IDE setuphttps://angular.dev/ai/develop-with-ai Best Pratices: https://angular.dev/context/best-practices.md |
Beta Was this translation helpful? Give feedback.
-
Hausaufgabe: Typeahead-SucheImplementiere eine Typeahead-Suche. Nutze als Basis dafür den Datenstrom
|
Beta Was this translation helpful? Give feedback.
-
Mein @service()-Decorator für AngularAls Antwort auf eure Frage. Ja, es geht! :-D https://github.com/angular-buch/website-articles/pull/38/files |
Beta Was this translation helpful? Give feedback.
-
import {Component, inject} from '@angular/core';
import {FormControl, FormGroup, ReactiveFormsModule} from "@angular/forms";
import {BookStore} from '../shared/book-store';
import {toSignal} from '@angular/core/rxjs-interop';
import {debounceTime, filter, switchMap} from 'rxjs';
@Component({
selector: 'app-book-search',
imports: [
ReactiveFormsModule
],
templateUrl: './book-search.html',
styleUrl: './book-search.scss'
})
export class BookSearch {
bs = inject(BookStore);
searchForm = new FormGroup({
search: new FormControl('')
});
typeAhead = toSignal(this.searchForm.controls.search.valueChanges.pipe(
debounceTime(400),
filter(t => t !== null),
filter(t => t.length >= 3),
switchMap(t => this.bs.search(t))
));
} @let d = searchForm.controls;
<h3>Suche nach Büchern</h3>
<form [formGroup]="searchForm">
<div class="form-group">
<label for="search">Filter-Zeichenkette</label>
<input [formControl]="d.search" class="form-control" id="search">
</div>
</form>
<h3>Suchergebnisse</h3>
<ul>
@for (x of typeAhead(); track $index) {
<li>
{{ x.title }}
</li>
}
</ul> Beispiellösung aus dem Kurs |
Beta Was this translation helpful? Give feedback.
-
import { JsonPipe } from '@angular/common';
import { HttpErrorResponse } from '@angular/common/http';
import { Component, inject } from '@angular/core';
import { toSignal } from '@angular/core/rxjs-interop';
import { ActivatedRoute, RouterLink } from '@angular/router';
import { catchError, map, of, switchMap } from 'rxjs';
import { BookStore } from '../shared/book-store';
@Component({
selector: 'app-book-details-page',
imports: [JsonPipe, RouterLink],
templateUrl: './book-details-page.html',
styleUrl: './book-details-page.scss'
})
export class BookDetailsPage {
bs = inject(BookStore);
router = inject(ActivatedRoute);
book = toSignal(this.router.paramMap.pipe(
map(x => x.get('isbn') || ''),
switchMap(isbn => this.bs.getSingle(isbn).pipe(
catchError((err: HttpErrorResponse) => of({
title: 'Fehler',
description: err.message
}))
))
));
// withComponentInputBinding() in app.config.ts
// isbn = input.required();
// logEffect = effect(() => console.log('Die ISBN lautet', this.isbn()));
} <pre>
{{ book() | json }}
</pre>
<a routerLink="/books/9783864909467">Gehe zu Angular</a><br>
<a routerLink="/books/9783864905520">Gehe zu React</a><br>
<a routerLink="/books/404">Gehe zu Fehler</a><br> |
Beta Was this translation helpful? Give feedback.
-
i18n von AngularPer Translocohttps://github.com/ngneat/transloco ngx-translate |
Beta Was this translation helpful? Give feedback.
-
Achtung, ngrx/platform#4787 (PSA: Angular v20 and NgRx v20)
Bei der Anwendung NgRx einrichten npm install @ngrx/store@latest --save --legacy-peer-deps
npm install @ngrx/schematics@latest --save --legacy-peer-deps
npm install @ngrx/effects@latest --save --legacy-peer-deps
npm install @ngrx/store-devtools@latest --save --legacy-peer-deps Und in der "cli": {
"schematicCollections": [
"@schematics/angular",
"@ngrx/schematics"
]
} danach: ng g feature books/store/book --entity=false --api --defaults folgende Anpassungen in der import { ApplicationConfig, provideBrowserGlobalErrorListeners, provideZonelessChangeDetection, isDevMode } from '@angular/core';
import { provideRouter, withComponentInputBinding } from '@angular/router';
import { routes } from './app.routes';
import { provideHttpClient } from '@angular/common/http';
import { provideEffects } from '@ngrx/effects';
import { provideStoreDevtools } from '@ngrx/store-devtools';
import { bookFeature } from './books/store/book.reducer';
import { BookEffects } from './books/store/book.effects';
import { provideState, provideStore } from '@ngrx/store';
export const appConfig: ApplicationConfig = {
providers: [
provideBrowserGlobalErrorListeners(),
provideZonelessChangeDetection(),
provideRouter(routes,
/* withDebugTracing() */
/* withInMemoryScrolling({ scrollPositionRestoration: 'top'}) */
withComponentInputBinding()),
provideHttpClient(),
// NgRx Neu Einfügen:
provideStore(),
provideEffects(),
provideStoreDevtools({ maxAge: 25, logOnly: !isDevMode() }),
provideState(bookFeature),
provideEffects(BookEffects)
]
}; |
Beta Was this translation helpful? Give feedback.
Uh oh!
There was an error while loading. Please reload this page.
-
Herzlich Willkommen! 🎉 Hier können wir während der Schulung Links und Codeschnipsel teilen.
Beta Was this translation helpful? Give feedback.
All reactions