Для углового множественного выбора требуется массив, поэтому вам нужна переменная, которая была массивом
//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;
}
}