3

我已按照下面提到的步骤进行操作,并且能够达到以下图像。

  1. 安装 6.9.1 版本的 nodejs。它带有 npm 3.10.8
  2. 然后我按照以下安装步骤
  3. 现在,当我尝试使用<ngb-datepicker></ngb-datepicker>时,我能够看到这种类型的屏幕。 ngb-datepicker

但我无法理解如何使用input[ngbDatepicker]

我试过<input ngbDatepicker />但只出现一个文本框。当我关注它时,它没有显示日期选择器。

这是我正在使用的链接。

4

2 回答 2

6

要在焦点上显示日期选择器,您可以使用以下模板引用focus来使用输入事件:

<input ngbDatepicker #d="ngbDatepicker" (focus)="d.open()">

或者您可以按照 Datepicker 的示例toggle在按钮单击时添加 datepicker 的触发事件Datepicker in a popup

// Component
@Component({
  selector: 'ngbd-datepicker-popup',
  templateUrl: './datepicker-popup.html'
})
export class NgbdDatepickerPopup {
  model;
}

// HTML
<div class="input-group">
  <input class="form-control" placeholder="yyyy-mm-dd" name="dp" [(ngModel)]="model" ngbDatepicker #d="ngbDatepicker">
  <div class="input-group-addon" (click)="d.toggle()" >
    <img src="img/calendar-icon.svg" style="width: 1.2rem; height: 1rem; cursor: pointer;"/>
  </div>
</div>
于 2016-11-16T06:47:25.777 回答
3

经过大量工作并得到ranakrunal9的建议。我已经达到了以下代码库。它在各个方面都运行良好(但我仍然只有一个问题,如果我在日期选择器之外单击,日期选择器不会被关闭)这是plunker

import {Component, NgModule} from '@angular/core'
import {BrowserModule} from '@angular/platform-browser'
import {NgbModule, NgbDateParserFormatter, NgbDateStruct} from '@ng-bootstrap/ng-bootstrap';
import { Component, OnInit, Input, forwardRef } from '@angular/core';
import { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';
import { FormGroup, FormBuilder, Validators } from '@angular/forms';

@Component({
  imports: [
    NgbModule,
    BrowserModule,
    NgbDateParserFormatter
  ],
  selector: 'my-app',
  templateUrl: 'template.html'
})
export class App {


}

@NgModule({
  imports: [ BrowserModule, 
    NgbModule.forRoot()],
  providers : [
    {provide: NgbDateParserFormatter, useClass: forwardRef(() => CustomDateParserFormatter)}
  ],
  declarations: [ App ],
  bootstrap: [ App ]
})
export class AppModule {}



export class CustomDateParserFormatter extends NgbDateParserFormatter {
  parse(value: string): NgbDateStruct {
    if (value) {
      const dateParts = value.trim().split('/');
      /*
     Put your logic for parsing
      */
    }
    return null;
  }

  format(date: NgbDateStruct): string {
    return date ?
        date.day+'/'+date.month+'/'+date.year :
        '';
  }
}
于 2016-11-21T06:49:43.393 回答