开发者问题收集

Moment js 导入无法与 angular 一起正确运行

2018-07-01
2064

我遇到了这样的问题。我正在构建一个 angular 应用程序,我将在其中使用 moment-range 和 moment js。

我已将其导入到需要它的组件中。这是 component.ts 文件。它给了我这样的错误。

import { Component, OnInit } from '@angular/core';
import {FormControl, FormGroup, FormGroupDirective, NgForm, Validators} from '@angular/forms';
import {ErrorStateMatcher} from '@angular/material/core';
import {ReservationService} from "../shared/reservation.service";
import {Router} from "@angular/router";
import {Reservation} from "../shared/reservation";
import * as $ from 'jquery';
import { BootstrapAlertService, BootstrapAlert } from 'ngx-bootstrap-alert';


import Moment from 'moment';
import { extendMoment } from 'moment-range';

const moment = extendMoment(Moment);



export interface Time {
  value: string;
  viewValue: string;
}

export interface Year {
  value: string;
  viewValue: string;
}

export interface Role {
  value: string;
  viewValue: string;
}



export class MyErrorStateMatcher implements ErrorStateMatcher {
  isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {
    const isSubmitted = form && form.submitted;
    return !!(control && control.invalid && (control.dirty || control.touched || isSubmitted));
  }
}

@Component({
  selector: 'app-makereservation',
  templateUrl: './makereservation.component.html',
  styleUrls: ['./makereservation.component.css'],
  providers: [ReservationService]
})
export class MakereservationComponent implements OnInit {

  public show = false;
  public reservation:Reservation=new Reservation();
  date:string;
  lab:string;
  from:string;
  to:string;
  name:string;
  email:string;
  role:string;
  year:string;
  reason:string;

  time: Time[] = [
    {value: '8.00', viewValue: '8.00'},
    {value: '9.00', viewValue: '9.00'},
    {value: '10.00', viewValue: '10.00'},
    {value: '11.00', viewValue: '11.00'},
    {value: '12.00', viewValue: '12.00'},
    {value: '13.00', viewValue: '13.00'},
    {value: '14.00', viewValue: '14.00'},
    {value: '15.00', viewValue: '15.00'},
    {value: '16.00', viewValue: '16.00'},
    {value: '17.00', viewValue: '17.00'}

  ];

  years: Year[] = [
    {value: '1st Year', viewValue: '1st Year'},
    {value: '2nd Year', viewValue: '2nd Year'},
    {value: '3rd Year', viewValue: '3rd Year'},
    {value: '4th Year', viewValue: '4th Year'},
  ];

  roles: Role[] = [
    {value: 'Student', viewValue: 'Student'},
    {value: 'Lecturer', viewValue: 'Lecturer'},
    {value: 'Professor', viewValue: 'Professor'},
    {value: 'Assistant lecturer', viewValue: 'Assistant lecturer'},
    {value: 'Instructor', viewValue: 'Instructor'},
  ];



  constructor(private router: Router, private reservationService: ReservationService,private bootstrapAlertService:BootstrapAlertService) { }

  ngOnInit() {

  }

  emailFormControl = new FormControl('', [
    Validators.required,
    Validators.email,
  ]);

  matcher = new MyErrorStateMatcher();

  getcurrentReservations(){
    if(this.lab && this.date) {
      this.reservation.date = this.date;
      this.reservation.lab = this.lab;
      this.reservationService.getcurrentReservations(this.reservation).subscribe((res: any) => {
        this.reservationService.reservations = res as Reservation[];

      });
    }
  }

  showYear(){
    if(this.role=="Student"){
      $( "#year" ).show();
    }
  }

  makereservation(){
    this.reservation.date=this.date;
    this.reservation.from=this.from;
    this.reservation.to=this.to;
    this.reservation.lab=this.lab;
    this.reservation.name=this.name;
    this.reservation.email=this.email;
    this.reservation.role=this.role;
    this.reservation.year=this.year;
    this.reservation.reason=this.reason;
    this.reservationService.makereservation(this.reservation).subscribe((res:any)=>{
      this.bootstrapAlertService.alert(new BootstrapAlert("Succesfully add a reservation!", "alert-success"));
      this.router.navigate(['/makereservation']);
    })

  }

}

这是浏览器控制台中显示的错误。

Uncaught TypeError: Cannot set property 'range' of undefined
    at Object.u [as extendMoment] (moment-range.js:1)
    at eval (makereservation.component.ts:14)
    at Object../src/app/makereservation/makereservation.component.ts (main.bundle.js:278)
    at __webpack_require__ (inline.bundle.js:55)
    at eval (app.routing.ts:13)
    at Object../src/app/app.routing.ts (main.bundle.js:212)
    at __webpack_require__ (inline.bundle.js:55)
    at eval (app.module.ts:3)
    at Object../src/app/app.module.ts (main.bundle.js:204)
    at __webpack_require__ (inline.bundle.js:55)

在 webStrom 中,它向我显示了一个错误,并在 import 语句中的 Moment 一词下划线,并表示 node_modules/moment/moment 中没有默认导入。

有人能帮我找到这个问题的解决方案吗?谢谢!

2个回答

这似乎可以修复 Angular 应用程序的问题:

import * as moment from 'moment';
import { extendMoment } from 'moment-range';

const { moment } = extendMoment(moment);

仍在使用:

const range1 = moment.range('2018-01-20', '2018-01-27');
repoleved
2018-07-13

这似乎可以修复 Angular 7+ 应用程序的问题:

import * as moment from 'moment';
import { extendMoment } from 'moment-range';

const { range } = extendMoment(moment);

仍在使用:

const range1 = range('2018-01-20', '2018-01-27');
Stéphane GRILLON
2019-11-04