在Angular中添加指令后,禁用属性不起作用,如果没有指令,则工作

时间:2018-04-14 12:57:03

标签: angular angular-directive angular-forms

我有一个输入字段,在添加指令后没有被禁用。如果指令被删除它完全正常。

 <div class="form-group row">
      <label class="col-4 col-form-label">Date<span class="text-danger">*</span></label>
      <div class="col-7">
          <input type="text"
               appDatePicker
               [disabled]="currentOperation === 'view' || currentOperation ==='delete'"
               required
               value="{{holiday.off_date}}"
               name="description"
               [(ngModel)]="holiday.off_date"
               class="form-control"
               placeholder="01/01/2014">
      </div>
  </div>

指令

import {Directive, ElementRef, forwardRef, OnInit} from '@angular/core';
import {ControlValueAccessor, NG_VALUE_ACCESSOR} from '@angular/forms';

declare const $: any;

@Directive({
  selector: '[appDatePicker]',
  providers: [{
    provide: NG_VALUE_ACCESSOR, useExisting:
      forwardRef(() => DatePickerDirective),
    multi: true
  }]
})
export class DatePickerDirective implements OnInit, ControlValueAccessor {

  value: string;

  constructor(private el: ElementRef) {

  }


  ngOnInit() {
    $(this.el.nativeElement).datepicker({
      autoclose: true,
      todayHighlight: true,
      format: 'dd/mm/yyyy'
    }).on('change', e => this._onChange(e.target.value));
  }


  private _onChange(_) {
  }

  private _onTouched(_) {
  }

  registerOnChange(fn: any): void {
    this._onChange = fn;
  }

  registerOnTouched(fn: any): void {
    this._onTouched = fn;
  }

  setDisabledState(isDisabled: boolean): void {
  }

  writeValue(val: string): void {
    this.value = val;
  }


}

我担心这个问题与我之前提出的问题有关。该问题的链接是here

我刚刚尝试过禁用属性,也许其他属性也无效。

任何帮助都将受到高度赞赏。

1 个答案:

答案 0 :(得分:0)

搜索后我发现ControlValueAccessor有一个方法可以用来禁用状态。通过添加它可以实现以下目的。

  setDisabledState(isDisabled: boolean): void {
    $(this.el.nativeElement).attr('disabled', isDisabled);
  }