TypeError:v.context.$ implicit不是函数

Onu*_*der 6 typescript ionic2

我是Typescript的新手.我已经3天了.我想从Firebase访问数据.我访问并列出.当我想用(Click)="item()"传递给另一个页面时,我收到错误.我在哪里做错了.

数据api.service.ts

import {Injectable} from '@angular/core';
import {Http,Response} from '@angular/http';

import 'rxjs';
import {Observable} from 'rxjs/Observable';
@Injectable()

export class DataApi {


 private url = 'https://ionic2-9dc0a.firebaseio.com/.json';   // https://ionic2-9dc0a.firebaseio.com

 currentphone : any = {};
constructor(private http:Http){
}
  getAdress(){
    return new Promise(resolve =>{
      this.http.get(`${this.url}`) 
      .subscribe(res => resolve(res.json()))
    });
  }





  }
Run Code Online (Sandbox Code Playgroud)

about.ts

import { Component } from '@angular/core'; 
import { IonicPage, NavController, NavParams } from 'ionic-angular';
import {DataApi} from '../../app/shared/shared';
import {Http, HttpModule} from '@angular/http';


import  {TeamsPage} from '../teams/teams';

 @IonicPage()
 @Component({
 selector: 'page-about',
 templateUrl: 'about.html',
  })
 export class AboutPage {

 names: any;
 constructor(public navCtrl: NavController, public navParams: NavParams, 
 public dataApi:DataApi, public http:Http) {

 }

 item(){
    this.navCtrl.push(TeamsPage);
  }

 ionViewDidLoad(){
    this.dataApi.getAdress().then(data => this.names= data[0]);
    console.log("willloaded");


   }


}
Run Code Online (Sandbox Code Playgroud)

about.html

   <ion-header>

   <ion-navbar>
   <ion-title>Select Tournament </ion-title>
   </ion-navbar>

   </ion-header>


  <ion-content>
     <ion-list>    
       <button ion-item *ngFor="let item of names" (click)="item()">
         <h2> {{item.name}}</h2>
       </button>
     </ion-list>

 </ion-content>
Run Code Online (Sandbox Code Playgroud)

data.json

 [
 [
{
  "id": 15,
  "name": "Sahne Sistemleri",
  "image": "sahne/1.jpg",

   {

     "image": "sahne/1.jpg"
   }

},
{
  "id": 16,
  "name": "Görüntü Sistemleri",
  "image": "sahne1/1.jpg"
},
{
  "id": 17,
  "name": "Podyum Sistemleri",
  "image": "sahne2/1.jpg"
},
{
  "id": 18,
  "name": "Masa, Sandalye ve Loca Gruplar?",
  "image": "sahne3/1.jpg"
},
{
  "id": 19,
  "name": "Çad?r Sistemleri",
  "image": "sahne4/1.jpg"
},
{
  "id": 20,
  "name": "Mobil Jenaratör Hizmetleri",
  "image": "sahne5/1.jpg"
},
{
  "id": 21,
  "name": "Simultane(Çeviri) Sistemleri",
  "image": "sahne6/1.jpg"
}
]
]
Run Code Online (Sandbox Code Playgroud)

aboutpage

在此输入图像描述

单击其中一个项目

teampage 在此输入图像描述

Sur*_*Rao 5

由于TeamsPage是 IonicPage,因此它是延迟加载的。

检查IonicPage。避免TeamsPage在其他页面中导入。为了推送页面,请使用与页面等效的字符串。例如:

item(){
    this.navCtrl.push('TeamsPage');
  }
Run Code Online (Sandbox Code Playgroud)

并删除导入。

或者,如果您想使用自定义字符串,请将其设置在TeamsPage.

@IonicPage({
  name:'teams-page'
})
Run Code Online (Sandbox Code Playgroud)

在推动页面的同时,

   item(){
        this.navCtrl.push('teams-page');
      }
Run Code Online (Sandbox Code Playgroud)

其次,您的函数名称item()似乎与您的 for 循环变量发生冲突item。将其更改为:

   <button ion-item *ngFor="let n of names" (click)="item()">
      <h2> {{n.name}}</h2>
   </button>
Run Code Online (Sandbox Code Playgroud)

  • 更改函数名称..您的循环项和函数名称必须冲突 (2认同)

小智 5

您只需更改 HTML 中的方法名称非常简单,因为在 *ngFor 迭代器中您使用了相同的循环名称和方法名称..!

 <button ion-item *ngFor="let **item** of names" (click)="**item**()">
     <h2> {{item.name}}</h2>
   </button>
Run Code Online (Sandbox Code Playgroud)