Угловые разделенные запятыми значения в объекте данных - PullRequest
0 голосов
/ 06 февраля 2019

Имеют данные массива со столбцом в виде значений, разделенных запятыми, таких как

Firstname: name.
Lastname:lastname
Cities lived: ex,ex,CV

Теперь хотел использовать города, которые жили как mat select, как этого добиться?

Ответы [ 2 ]

0 голосов
/ 07 февраля 2019

проверить все ответы, наконец, с этим.

Уровень компонента с учетом данных, уже находящихся в массиве, Mat select ожидает массив.

citydata = this.data.Cities.split(',')

HTML

<mat-select [placeholder]="placeHolder" [formControl]="control" multiple>
<mat-option *ngFor="let item of citydata" [value]="item">{{item}}
    </mat-option>

  </mat-select>
0 голосов
/ 06 февраля 2019

Для углового множественного выбора требуется массив, поэтому вам нужна переменная, которая была массивом

//create two functions transform and parse
transform(user:User)
{
    return {...user,
            cities:user.cities?user.cities.join(','):null
    }
}
parse(userData:any)
{
    return {...userData,
            cities:userData.cities?userData.split(','):null
    }
}
//then you has two variables
user={firstName:..,lastName:..,cities:"ex,ex,CV"}
userData=this.transform(user)
//your "model" is userData, when you can obtain a real user you can do
this.user=this.parse(this.userData)

Другой вариант - создать пользовательский элемент управления формы, например stackblitz

@Component({
  selector: 'multiselect-to-string',
  template: `
  <mat-form-field>

  <mat-select [placeholder]="placeHolder" [formControl]="control" multiple>
    <ng-container *ngIf="!key || !text">
    <mat-option *ngFor="let item of sourceList" [value]="item">
         {{item}}
    </mat-option>
    </ng-container>
    <ng-container *ngIf="key && text">
    <mat-option *ngFor="let item of sourceList" [value]="item[key]">
        {{item[text]}}
    </mat-option>
    </ng-container>
  </mat-select>
  </mat-form-field>

  `,
  providers: [
    {
      provide: NG_VALUE_ACCESSOR,
      useExisting: forwardRef(() => MultiSelectToStringComponent),
      multi: true
    }]
})
export class MultiSelectToStringComponent implements ControlValueAccessor,OnInit,OnDestroy {
  @Input('placeholder')placeHolder;
  @Input('source')sourceList;
  @Input()key;
  @Input()text;

  onChange;
  onTouched;
  control=new FormControl();
  private alive:boolean=true;

  ngOnInit()
  {
     this.control.valueChanges.pipe(takeWhile(() => this.alive)).subscribe(value=>{
       if (this.onChange)
        this.onChange(value?value.join(','):null)
     })
  }
  ngOnDestroy()
  {
    this.alive=false;
  }
  writeValue(value: any[]|any): void {
    this.control.setValue(value?value.split(','):null);
  }

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

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

}
...