javascript - 类型错误 : Cannot read property 'username' of undefined?

标签 javascript ecmascript-6 angular ionic2

我正在使用 Ionic 2 开发一个应用程序,但出现以下错误。当我删除 [(ngModel)]="register.username"错误消失。

TypeError: Cannot read property 'username' of undefined in [register.username in RegisterPage@15:19]
<ion-navbar *navbar>
  <ion-title>Register</ion-title>
</ion-navbar>

<ion-content class="login-page">

  <ion-list>
    <div class="logo">
      <img src="img/appicon.svg">
    </div>

    <form #signupForm="ngForm" novalidate>
      <ion-item>
        <ion-label floating primary>Username</ion-label>
        <ion-input [(ngModel)]="register.username" ngControl="username" type="text" #username="ngForm" required>
        </ion-input>
      </ion-item>
      <p [hidden]="username.valid || submitted == false" danger padding-left>
        Username is required
      </p>

      <ion-item>
        <ion-label floating primary>Password</ion-label>
        <ion-input [(ngModel)]="register.password" ngControl="password" type="password" #password="ngForm" required>
        </ion-input>
      </ion-item>
      <p [hidden]="password.valid || submitted == false" danger padding-left>
        Password is required
      </p>

      <div padding>
        <button (click)="onSignup(signupForm)" type="submit" primary block>Create</button>
      </div>
    </form>
  </ion-list>

</ion-content>

注册.js

import { App, Page, NavController } from 'ionic/ionic';
@Page({
  templateUrl: 'build/pages/register/register.html'
})

export class RegisterPage {
  constructor(nav: NavController) {
    this.nav = nav;
  }

  onSignup(form) {
    // console.log(form);
    // if (form.valid) {
    //   this.nav.push();
    // }
  }
}

想知道我做错了什么吗?我应该阅读什么文档? (如果您想了解更多信息,请告诉我)

最佳答案

也许您的register对象是异步加载的。为了防止这种情况,只需使用 Elvis 运算符:register?.username 或在表单周围使用 ngIf:

<form #signupForm="ngForm" novalidate *ngIf="register">
  <ion-item>
    <ion-label floating primary>Username</ion-label>
    <ion-input [(ngModel)]="register.username"
               ngControl="username" type="text"
               #username="ngForm" required>
    </ion-input>
  </ion-item>
  (...)
</form>

编辑

register 对象设置为空对象应该可以解决您的问题:

import { App, Page, NavController } from 'ionic/ionic';
@Page({
  templateUrl: 'build/pages/register/register.html'
})

export class RegisterPage {
  constructor(nav: NavController) {
    this.nav = nav;
    this.register = {};
  }

  onSignup(form) {
    // console.log(form);
    // if (form.valid) {
    //   this.nav.push();
    // }
  }
}

希望对你有帮助 蒂埃里

关于javascript - 类型错误 : Cannot read property 'username' of undefined?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35112305/

相关文章:

javascript - 使用 javascript 中的第 n 个子项指定图像在放置区域的位置

javascript - 转化为 if/else 语句

javascript - Google map 纹理 map

html - 我们怎样才能使固定左侧导航栏旁边的容器响应?

javascript - Angular 2 模板解析错误

javascript - jQuery:如果 div 不存在则添加它?

javascript - 声明 const 时遇到问题

javascript - 特定祖先的访问方法

javascript - 检测 JavaScript 中的 for...of 循环支持

dart - Angular 2和函数$ interval