2016-07-05 55 views
1

我用NG2的自举日期选择器,当我点击日期选择器,它仍然显示,如何隐藏呢?我的HTML代码。请到帮帮我,谢谢如何让NG2的自举日期选择器隐藏

<input type="text" [ngModel]="dt.toLocaleDateString()" (focus)="showDatePicker = true" style="width:300px;"> 
 
<div *ngIf="showDatePicker" style="position: absolute; z-index:10; min-height:290px;"> 
 
    <datepicker [(ngModel)]="dt" [showWeeks]="true" ></datepicker> 
 
</div>

回答

0

我有同样的问题。目前它的接缝是不可能的。作者正在接受新版本的工作。请参阅回购:HERE

0

您可以使用类名称和ID使用事件目标(click)=“close($ event.target)”关闭datepicket弹出窗口(即DatePickerPopupDirective),它适用于我。

在我datepicker.component.html模板:

<div *ngIf="opened" class="dateclass"> 
<datepicker [(ngModel)]="dt" [minDate]="minDate" [formatDayHeader]="E" 
    (click)="close($event.target)" 
    [showWeeks]="false"></datepicker> 
</div> 

因为NG2的自举日期选择器采用“BTN BTN-默认BTN-SM”作为类名日期和一年中,我们使用的ID和类名中,如果条件。

public close(e:HTMLElement): void { 
    if(e.className == 'btn btn-default btn-sm' && e.id !== 'undefined-title'){ 
    this.opened = false; 
    } 
} 

我的整个日期选取器组件的样子:

import { Component, OnInit, Input } from '@angular/core'; 
import {CORE_DIRECTIVES} from '@angular/common'; 
import {DATEPICKER_DIRECTIVES} from 'ng2-bootstrap/ng2-bootstrap'; 
import { FORM_DIRECTIVES }from '@angular/forms'; 

@Component({ 
    moduleId: module.id, 
    selector: 'app-datepicker', 
    templateUrl: 'datepicker.component.html', 
    directives: [DATEPICKER_DIRECTIVES, FORM_DIRECTIVES, CORE_DIRECTIVES], 
    styleUrls: ['datepicker.component.css'], 
    exportAs: 'dateref' 
}) 
export class DatepickerComponent implements OnInit { 
    @Input() private dt: Date = new Date(); 
    public minDate: Date = void 0; 
    public events: Array<any>; 
    private opened: boolean = false; 
    constructor() { 
    this.minDate = new Date(); 
    } 
    public getDate(): any { 
    return (this.dt && this.dt.getTime()); 
    } 

    public open(): void { 
    this.opened = !this.opened; 
    } 

    public close(e:HTMLElement): void { 
    if(e.className == 'btn btn-default btn-sm' && e.id !== 'undefined-title'){ 
    this.opened = false; 
    } 
    } 
ngOnInit() { 
} 
} 

在我父模板,我用EXPORTAS 'dateref' 指的@ViewChild( 'DP')日期选择器;如:

<app-datepicker #dp="dateref"></app-datepicker> 
-1

这是我的代码,它工作正常:

<div class="input-group"> 
    <input type="text" class="form-control " 
      (focus)="showDatePicker = !showDatePicker" name="inputBeginDate" 
      value="{{dt | date:'MM/dd/yy'}}"/> 
    <span class="input-group-addon" dropdownToggle 
      (click)="showDatePicker = !showDatePicker"><i class="fa fa-calendar"></i></span> 
    <div *ngIf="showDatePicker" 
     style="position: absolute; z-index:10; min-height:290px;"> 
     <datepicker name="date" [showWeeks]="false" [(ngModel)]="dt" (ngModelChange)="setDate(dt);getInvoices(invoiceFilters)" (selectionDone)="showDatePicker = false"></datepicker> 
    </div> 
</div> 
+0

你应该,在一般情况下,尽量提供_why_你的代码的作品是什么提问者应以不同的方式来做解释和让自己的代码工作,而不是只提供一个片段。 –