A continuación, le mostramos una forma rápida de conocer lo que está sucediendo:
Cuando hiciste lo siguiente:
¿nombre? : cuerda
Le estaba diciendo a TypeScript que era opcional. Sin embargo, cuando lo hizo:
let name1 : string = person.name;
No dejaste otra opción. Necesitaba tener una Unión que refleje el tipo indefinido:
let name1 : string | undefined = person.name;
Usando su respuesta, pude esbozar lo siguiente, que es básicamente, una interfaz, una clase y un objeto. Encuentro este enfoque más simple, no importa si usted no lo hace.
interface iPerson {
fname? : string,
age? : number,
gender? : string,
occupation? : string,
get_person?: any
}
class Person implements iPerson {
fname? : string;
age? : number;
gender? : string;
occupation? : string;
get_person?: any = function () {
return this.fname;
}
}
const person1 : Person = {
fname : 'Steve',
age : 8,
gender : 'Male',
occupation : 'IT'
}
const p_name: string | undefined = person1.fname;
const person2: Person = new Person();
person2.fname = 'Steve';
person2.age = 8;
person2.gender = 'Male';
person2.occupation = 'IT';
console.log('person1 : ', p_name);
console.log('person2 : ', person2.get_person());