Angular2 @Injectable не работает
У меня есть @Injectable
класс с get-функцией в Service.ts создать. Эта функция должна вернуть один массив, а также получить любой массив. Но это возвращается null
, Если я напишу это прямо в @Component
затем он получает массив. Что я делаю неправильно?
service.ts
@Injectable()
export class Arr_selected {
private arr = [];
get(arr_selected: any[]){
for(let key in arr_selected) {
if (arr_selected.hasOwnProperty(key)) {
this.arr.push([key]);
return this.arr;
}
}
console.log(this.arr);
}
}
component.ts
import {Arr_selected} from './service.ts';
export class Component implements DoCheck, OnChanges, OnInit {
....
constructor( public arr_selected: Arr_selected)
.....
ngOnInit{
let chk = this.ChkBoxValue;
let arr = [];
/// **this not working Array is null**/////
arr=(this.arr_selected.get(this.ChkBoxValue));
/// **this is working Array is not null**////
for (let key in this.ChkBoxValue) {
if (this.ChkBoxValue.hasOwnProperty(key)) {
arr.push(this.ChkBoxValue[key]);
}
}
console.log(arr);
}}
2 ответа
Я думаю ниже должно работать
@Injectable()
export class Arr_selected {
get(arr_selected: any[]){
arr = [];
for(let key in arr_selected) {
if (arr_selected.hasOwnProperty(key)) {
arr.push([key]);
return this.arr;
}
}
console.log(this.arr);
}
Я думаю, что "этот" оператор вызывает проблемы для вас. Вы также определили arr в компоненте. Это может противоречить, какой ARR использовать.
Above code you have written your file name as service.ts
и импорт из./servece.ts
import {Arr_selected} from'./servece.ts;
Может быть здесь ошибка при вводе, вы также добавляете свой сервис в провайдера компонента?