【发布时间】:2022-01-12 04:59:57
【问题描述】:
我在尝试禁用日期选择器中的某些日期时遇到了一些问题。我在打字稿中自定义的日期选择器如下:
import { DateFormatter } from './ng2-bootstrap/date-formatter';
import { DatePickerComponent } from './ng2-bootstrap/datepicker.component';
import * as moment from 'moment-timezone';
@Component({
selector: '[acn-datepicker-popup]',
templateUrl: './datepicker-popup.component.html',
inputs: [],
host: {}
})
export class DatepickerPopupComponent implements OnInit {
@Input() datepickerDirective: any;
@Input() minDate: moment.Moment;
@Input() maxYears: number;
@Input() alignRight: boolean = false;
@Input() disabledDates: string;
private dateFormat: string = 'DD/MM/YYYY';
private earliestDate: string = '01/01/1970';
datePickerCmp: DatePickerComponent;
datepickerFormControl: FormControl;
selectedDate: moment.Moment;
dateFormatter: DateFormatter = new DateFormatter();
constructor(private _datePickerCmp: DatePickerComponent, @Inject('datepickerFormControl') private _datepickerFormControl: FormControl) {
this.datePickerCmp = _datePickerCmp;
this.datepickerFormControl = _datepickerFormControl;
if (this.datepickerFormControl.value && this.dateFormatter.isValid(this.datepickerFormControl.value, this.dateFormat)) {
this.selectedDate = moment(this.datepickerFormControl.value, this.dateFormat);
}
}
ngOnInit() {
var splits = this.disabledDates.toString().split(";");
for(let i = 0; i < splits.length; i++){
console.log("Dates" + splits[i]);
}
}
我在 HTML 中的日期选择器组件:
<div class="col-sm-6 form-group has-feedback">
<label for="testDte">TEST DATE<span class="text-danger">*</span></label>
<div class="input-group" [(datepicker-popup)]="bookingModel.controls.testDte" [disabledDates]="bkDatesListStr">
<input type="text" [formControl]="bookingModel.controls.testDte" class="form-control" maxlength="10" style="border-right:transparent">
<span class="input-group-btn" align="right">
<button class="btn btn-square btn-white-primary form-control" type="button"><i class="fa fa-calendar"></i></button>
</span>
</div>
</div>
我设法在 ngOnInit() 中传递了要禁用的日期。 splits 变量包含要在日期选择器中灰显的日期列表。但是,我不知道如何在日期选择器中设置要禁用的日期。有什么想法吗?
谢谢!
【问题讨论】:
标签: angular typescript date datepicker