为了账号安全,请及时绑定邮箱和手机立即绑定

错误 TypeError:无法在新的 UserComponent 处设置未定义的属性

错误 TypeError:无法在新的 UserComponent 处设置未定义的属性

慕沐林林 2023-05-19 14:54:54
我是 Angular 的新手。我创建了一个简单的 UserComponent 并且在类中有一个名为 user 的对象,它包含用户的所有属性,如 firstname , lastname , age ,email 但是当我尝试在类构造函数中访问这些属性并设置它们的值时,我得到控制台中的错误提示无法设置未定义的名字属性或无法设置未定义的姓氏属性。我不知道是什么问题。这是代码:import { Component, OnInit } from '@angular/core';@Component({  selector: 'app-user',  templateUrl: './user.component.html',  styleUrls: ['./user.component.css'],})export class UserComponent {  user: {    firstname: string;    lastname: string;    age: number;    email: string;  };  constructor() {    this.user.firstname = 'Muhammad';    this.user.lastname = 'Shaeel';    this.user.age = 23;    this.user.email = 's123@yahoo.com';  }}
查看完整描述

4 回答

?
万千封印

TA贡献1891条经验 获得超3个赞

你定义了一个类型,但它的值仍然是undefined


import { Component, OnInit } from '@angular/core';


export class User {

    constructor(

        public firstname: string,

        public lastname: string,

        public age: number,

        public email: string,

    ) { }

}


@Component({

    selector: 'app-user',

    templateUrl: './user.component.html',

    styleUrls: ['./user.component.css'],

})

export class UserComponent {

    user: User;

    // Another option

    // user = new User('Muhammad', 'Shaeel', 23, 'shaeel678@gmail.com');


    constructor() {

        this.user = new User('Muhammad', 'Shaeel', 23, 'shaeel678@gmail.com');

    }

}

Stackblitz示例


查看完整回答
反对 回复 2023-05-19
?
MMMHUHU

TA贡献1834条经验 获得超8个赞

这对我有用


export class UserComponent {

user = {

firstname: '',

lastname: '',

age: 0,

email: ''

};


查看完整回答
反对 回复 2023-05-19
?
萧十郎

TA贡献1815条经验 获得超12个赞

如果您只是想user在内部包含对象UserComponent而不为其声明单独的类,您也可以这样做:


import { Component } from '@angular/core';


@Component({

  selector: 'app-user',

  templateUrl: './user.component.html',

  styleUrls: ['./user.component.css']

})

export class UserComponent {

  user = {

    firstname: "",

    lastname: "",

    age: -1,

    email: ""

  };


  constructor() {

    this.user.firstname = 'Muhammad';

    this.user.lastname = 'Shaeel';

    this.user.age = 23;

    this.user.email = 'shaeel678@gmail.com';

  }

}


查看完整回答
反对 回复 2023-05-19
?
浮云间

TA贡献1829条经验 获得超4个赞

用户对象为空,


试试下面


import { Component, OnInit } from '@angular/core';


export interface IUser: {

    firstname: string;

    lastname: string;

    age: number;

    email: string;

  };


@Component({

  selector: 'app-user',

  templateUrl: './user.component.html',

  styleUrls: ['./user.component.css'],

})

export class UserComponent {

  user: IUser = {

    firstname: '',

    lastname: '',

    age: null,

    email: ''

  };


  constructor() {

    this.user.firstname = 'Muhammad';

    this.user.lastname = 'Shaeel';

    this.user.age = 23;

    this.user.email = 'shaeel678@gmail.com';

  }

}


查看完整回答
反对 回复 2023-05-19
  • 4 回答
  • 0 关注
  • 117 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信