0

@Injectable在 Service.ts create 中有一个带有 get-function 的类。此函数应返回一个数组并获取任何数组。但它返回null。如果我直接在 a 中写这个@Component,那么它确实得到了数组。我究竟做错了什么?

服务.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);

  }

} 

组件.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); 
}}
4

2 回答 2

0
Above code you have written your file name as service.ts

并从 ./servece.ts 导入

   import {Arr_selected} from'./servece.ts;

可能是这里的打字错误,您是否在组件提供商中添加了您的服务?

于 2017-05-12T18:39:32.023 回答
0

我认为下面应该工作

@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);

      }

我认为“this”运营商给你造成了问题。您还在组件中定义了 arr 。这可能与使用哪个 arr 冲突。

于 2017-05-12T18:03:37.123 回答