Угловой материал: невозможно открыть указатель даты или выбрать элементы - PullRequest
0 голосов
/ 22 сентября 2018

Я делаю форму, и часть этой формы - средство выбора даты и селектор.Я решил использовать угловой материал для этого.Они появляются на моей странице (см. Ниже), но когда я нажимаю на их значки, они не открываются.Кто-то знает, что вызывает это?Я в основном скопировал HTML-код с официального сайта и добавил предложенные модули.

Вот как это выглядит.DatePicker и house выглядят нормально, но они просто не открываются, когда я нажимаю на их значки

enter image description here

Шаблон

   <div class="form-container">
    <form class="form" [formGroup]="mySignupForm" (ngSubmit)="onSignupSubmit()">
        <h2 class="heading-container"><span class="heading-secondary">Sign up</span></h2>
        <div class="form__core">
          <div class="form-group form__group">
            <mat-form-field>
              <input matInput placeholder="First name" [formControl]="firstName">
              <mat-error *ngIf="firstName.invalid">Error</mat-error>
            </mat-form-field>
          </div>
          <div class="form-group form__group">
            <mat-form-field>
              <input matInput placeholder="Last name" [formControl]="lastName">
              <mat-error *ngIf="lastName.invalid">Error</mat-error>
            </mat-form-field>
          </div>
          <div class="form-group form__group">
            <mat-form-field>
              <input matInput placeholder="Password" [formControl]="password1" pattern="^.*(?=.{4,10})(?=.*\d)(?=.*[a-zA-Z]).*$" type="password">
              <mat-error *ngIf="password1.invalid">Error</mat-error>
            </mat-form-field>
          </div>
          <div class="form-group form__group">
            <mat-form-field>
              <input matInput placeholder="Repeat password" [formControl]="password2" pattern="^.*(?=.{4,10})(?=.*\d)(?=.*[a-zA-Z]).*$" type="password">
              <mat-error *ngIf="password2.invalid">Error</mat-error>
            </mat-form-field>
          </div>
          <div class="form__group form-group">
            <mat-form-field>
              <input matInput (keyup)="checkUniqueUsername()" placeholder="Enter your username" [formControl]="username" required>
              <mat-error *ngIf="username.invalid || uniqueUsernameMessage">Error</mat-error>
            </mat-form-field>
            <!--<input-->
              <!--id="username"-->
              <!--(keyup)="checkUniqueUsername()"-->
              <!--[class.ng-invalid]="uniqueUsernameMessage"-->
              <!--[class.ng-valid]="!uniqueUsernameMessage && (username?.dirty || username?.touched) && !username?.errors"-->
              <!--name="username"-->
              <!--class="form__input form-control"-->
              <!--type="text"-->
              <!--placeholder="Username"-->
              <!--formControlName="username"-->
            <!--&gt;-->
          </div>
          <div class="form__group form-group">
            <mat-form-field>
              <input matInput [matDatepicker]="picker" placeholder="Date of birth (mm/dd/yyyy) ">
              <mat-datepicker-toggle matSuffix [for]="picker"></mat-datepicker-toggle>
              <mat-datepicker #picker></mat-datepicker>
            </mat-form-field>
          </div>
          <div class="form-group form__group">
            <mat-form-field>
              <input matInput placeholder="Email" (blur)="checkUniqueEmail()" [formControl]="email" type="email">
              <mat-error *ngIf="email.invalid">Error</mat-error>
            </mat-form-field>
          </div>
          <div class="form__group">
            <mat-form-field>
              <mat-select #select placeholder="Your house">
                <mat-option value="Slytherin">Slytherin</mat-option>
                <mat-option value="HufflePuff">Hufflepuff</mat-option>
                <mat-option value="Ravenclaw">Ravenclaw</mat-option>
                <mat-option value="Gryffindor">Gryffindor</mat-option>
              </mat-select>
            </mat-form-field>
            <button (click)="openSelect()">do it!</button>
          </div>
          <!--<div class="form__group form-group ">-->
            <!--<label class="form__label" for="house">House</label>-->
            <!--<select class="form__input form-control house" name="house" id="house" formControlName="house">-->
              <!--<option selected="selected" value="house">Pick your house</option>-->
              <!--<option value="slytherin">Slytherin</option>-->
              <!--<option value="hufflepuff">Hufflepuff</option>-->
              <!--<option value="ravenclaw">Ravenclaw</option>-->
              <!--<option value="Gryffindor">Gryffindor</option>-->
            <!--</select>-->
          <!--</div>-->
          <div class="form-group form__group">
            <label for="country" class="form__label">Country</label>
            <select class="form__input form-control country" name="country" id="country" formControlName="country">
          <option selected="selected" value="country">Choose your country</option>
          <option  *ngFor="let country of countries">{{country}}</option>
          </select>
          </div>
        </div>
        <div *ngIf="formSubmitted" class="row errors">
            <div class="errors__list justify-content-center">
                <div *ngIf="(firstName?.dirty || firstName?.touched) && firstName?.errors && firstName?.hasError('required')" class="errors__item">First name is required</div>

                <div *ngIf="(lastName?.dirty || lastName?.touched) && lastName?.errors && lastName?.hasError('required')" class="errors__item">Last name is required</div>

                <div *ngIf="(username?.dirty || username?.touched) && username?.errors && username?.hasError('required')" class="errors__item">Username is required</div>
                <div *ngIf="(username?.dirty || username?.touched) && username?.errors && username?.hasError('minlength')" class="errors__item">Username is too short</div>
                <div *ngIf="(username?.dirty || username?.touched) && username?.errors && username?.hasError('maxlength')" class="errors__item">Username is too long</div>
                <div *ngIf="uniqueUsernameMessage" class="errors__item">Username needs to be unique</div>

                <div *ngIf="(email?.dirty || email?.touched) && email?.errors && email?.hasError('required')" class="errors__item">Email address is required</div>
                <div *ngIf="(email?.dirty || email?.touched) && email?.errors && email?.hasError('email')" class="errors__item">You need a valid email address</div>
                <div *ngIf="uniqueEmailMessage" class="errors__item">Email needs to be unique</div>

                <div *ngIf="(password1?.dirty || password1?.touched) && password1?.errors && password1?.hasError('required')" class="errors__item">Password is required</div>
                <div *ngIf="(password1?.dirty || password1?.touched) && password1?.errors && password1?.hasError('pattern')" class="errors__item">Password needs letters AND numbers</div>
                <div *ngIf="(password1?.dirty || password1?.touched) && password1?.errors && password1?.hasError('minlength')" class="errors__item">Password should have more than 6 characters</div>
                <div *ngIf="(password1?.dirty || password1?.touched) && password1?.errors && password1?.hasError('maxlength')" class="errors__item">Password should have less than 15 characters</div>

                <div *ngIf="(password2?.dirty || password2?.touched) && password2?.errors && password2?.hasError('required')" class="errors__item">Repeat password is required</div>
                <div *ngIf="(password2?.dirty || password2?.touched) && !password2.hasError('required') && !equalPasswords()" class="errors__item">Passwords do not match</div>

                <div *ngIf="(birthDate?.dirty || birthDate?.touched) && birthDate?.errors && birthDate?.hasError('required')" class="errors__item">Birthday is required</div>
                <div *ngIf="(birthDate?.dirty || birthDate?.touched) && !birthDate?.hasError('required') && birthDate?.errors && birthDate?.hasError('pattern')" class="errors__item">Please enter a valid birthday</div>

                <div *ngIf="(country?.dirty || country?.touched) && country?.errors && country?.hasError('required')" class="errors__item">Country is required</div>
            </div>
        </div>
        <div class="form__buttons-container">
          <button class="btn btn-secondary confirm-button" (click)="onSignupSubmit()">Submit</button>
          <!--<button class="btn btn-secondary" [disabled]="!mySignupForm.valid && !equalPasswords() && !uniqueUsernameMessage" type="submit">Submit</button>-->
        </div>

    </form>
</div>

app.module.ts

@NgModule({
  declarations: [
  ],
  imports: [
    BrowserModule,
    BrowserAnimationsModule,
    CommonModule,
    FormsModule,
    AgmCoreModule.forRoot({
      apiKey: 'AIzaSyDFDGOMDXkdSHOkVaVbGjIwtMvqaTwVXCA'
    }),
    NgbModule.forRoot(),
    MatInputModule,
    MatCardModule,
    MatButtonModule,
    MatProgressSpinnerModule,
    MatSnackBarModule,
    MatToolbarModule,
    MatExpansionModule,
    MatFormFieldModule,
    MatDatepickerModule,
MatNativeDateModule,
    MatSelectModule,
    ReactiveFormsModule
  ],
  providers: [],
  bootstrap: [AppComponent]
})
export class AppModule {}

1 Ответ

0 голосов
/ 22 сентября 2018

Поле тега <mat-datepicker></mat-datepicker> отсутствует в HTML-источнике, который вы разместили.Пожалуйста, разместите полную HTML-страницу с тегом, чтобы я мог быть в курсе вашего источника, прежде чем ответить.Благодаря.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...