Ex 4
๋ฌธ์
/*
Intro:
As we introduced "type" to both User and Admin
it's now easier to distinguish between them.
Once object type checking logic was extracted
into separate functions isUser and isAdmin -
logPerson function got new type errors.
Exercise:
Figure out how to help TypeScript understand types in
this situation and apply necessary fixes.
*/
interface User {
type: 'user';
name: string;
age: number;
occupation: string;
}
interface Admin {
type: 'admin';
name: string;
age: number;
role: string;
}
export type Person = User | Admin;
export const persons: Person[] = [
{ type: 'user', name: 'Max Mustermann', age: 25, occupation: 'Chimney sweep' },
{ type: 'admin', name: 'Jane Doe', age: 32, role: 'Administrator' },
{ type: 'user', name: 'Kate Mรผller', age: 23, occupation: 'Astronaut' },
{ type: 'admin', name: 'Bruce Willis', age: 64, role: 'World saver' }
];
export function isAdmin(person: Person) {
return person.type === 'admin';
}
export function isUser(person: Person) {
return person.type === 'user';
}
export function logPerson(person: Person) {
let additionalInformation: string = '';
if (isAdmin(person)) {
additionalInformation = person.role;
}
if (isUser(person)) {
additionalInformation = person.occupation;
}
console.log(` - ${person.name}, ${person.age}, ${additionalInformation}`);
}
console.log('Admins:');
persons.filter(isAdmin).forEach(logPerson);
console.log();
console.log('Users:');
persons.filter(isUser).forEach(logPerson);
// In case you are stuck:
// https://www.typescriptlang.org/docs/handbook/2/narrowing.html#using-type-predicates
ํ์ด
ํ์ ๋ด๋ก์ ํ ํ์ ๋ณ ๊ฐ์ฒด์ ์์๋ฅผ ํ์ธํ๋ คํ๋ค.
ํจ์์ ๋ฆฌํด๊ฐ์ ํ์ ์ ์ถ๊ฐํด ํน์ ๊ฐ์ฒด ํ๋กํผํฐ๋ฅผ ์ฌ์ฉํ ์ ์๋๋ก ์ค์ ํ๋ค.
export const isAdmin = (person: Person): person is Admin => person.type === 'admin'
export const isUser = (person: Person): person is User => person.type === 'user'
Last updated
Was this helpful?