【问题标题】:Weird behavior when using Angular Material 2 table (Angular 2/Spring Boot backend)使用 Angular Material 2 表(Angular 2/Spring Boot 后端)时的奇怪行为
【发布时间】:2017-08-21 13:03:40
【问题描述】:

继续Using angular material 2 table to display the result from backend based on user's current location

我编写此代码的目的是当用户进入网站时,它会尝试询问用户当前位置。一旦我的前端获得当前的纬度/经度,它将传递给后端以根据用户的位置获取最近的餐厅,并使用角度材料表来显示它。但是当我在 Chrome 上测试时,我遇到了奇怪的行为,第一次主页不会立即显示结果,尝试刷新,不起作用,唯一让它起作用的方法是切换另一个标签,然后回到这个,它将在角度材料表中显示结果。

这是 home.component.ts 的代码

import { Component, OnInit } from '@angular/core';
import { Http, Response, URLSearchParams } from '@angular/http';
import { DataSource } from '@angular/cdk';
import { BehaviorSubject } from 'rxjs/BehaviorSubject';
import { Observable } from 'rxjs/Observable';
import 'rxjs/add/operator/startWith';
import 'rxjs/add/observable/merge';
import 'rxjs/add/operator/map';
import 'rxjs/add/observable/frompromise';
import { Restaurant } from '../restaurant/restaurant';
import { Category } from '../category/category';
import { RestaurantService } from '../restaurant/restaurant.service';


@Component({
  selector: 'app-home',
  templateUrl: './home.component.html',
  styleUrls: ['./home.component.css']
})
export class HomeComponent implements OnInit {
  displayedColumns = ['Id', 'Name', 'Category', 'Address', 'City'];
  dataSource: ExampleDataSource | null;

  constructor(http: Http) {
    //this.exampleDatabase = new ExampleHttpDatabase(http, this.location);
    this.dataSource = new ExampleDataSource(http);

  }

  ngOnInit() {
    this.dataSource.connect();
  }
}

export class ExampleDataSource extends DataSource<Restaurant> {
  private url = 'api/search/location';
  private params = new URLSearchParams();
  private lat;
  private lon;
  constructor(private http: Http) {
    super();
  }

  /** Connect function called by the table to retrieve one stream containing the data to render. */
  connect(): Observable<Restaurant[]> {
    // var location;
    // if (navigator.geolocation){
    //   var options = {timeout: 60000};
    //   location = navigator.geolocation.getCurrentPosition((position)=>{
    //     return position;
    //   },(err) =>{
    //     console.log("Error")
    //   }, options);
    // }
    // console.log("Locations: " + location);
    var result = this.getCurrentLocation().then((res) => 
    {
      return res;
    });
    return Observable.fromPromise(result);
  }


  disconnect() { }
  getPosition = () => {
    var latitude, longitude;
    return new Promise((resolve, reject) => {
      navigator.geolocation.getCurrentPosition((position) => {
        resolve(position.coords);
      }, (err) => {
        reject(err);
      });
    })
  }
  async getCurrentLocation(): Promise<Restaurant[]> {
    let coords = await this.getPosition();
    this.lat = coords['latitude'];
    this.lon = coords['longitude'];
    this.params.set('lat', this.lat);
    this.params.set('lon', this.lon);
    var result = this.http.get(this.url, { search: this.params }).map(this.extractData);
    return await result.toPromise();
  }
  extractData(result: Response): Restaurant[] {
    return result.json().map(restaurant => {
      return {
        id: restaurant.id,
        name: restaurant.restaurant_name,
        category: restaurant.category.map(c => c.categoryName).join(','),
        address: restaurant.address.address,
        city: restaurant.address.city.cityName
      }
    });
  }
}

我不知道我做错了什么..有人可以帮助我吗?完整代码请见https://github.com/zhengye1/Eatr/tree/dev

【问题讨论】:

    标签: javascript angularjs angular-material2


    【解决方案1】:

    终于解决了……

    我需要做的只是将 HomeComponent 类上的 ngOnInit 更改为关注

    async ngOnInit() {
        await this.dataSource.connect();
    }
    

    它有效..不知道为什么...

    【讨论】:

      猜你喜欢
      • 2018-03-15
      • 2019-06-20
      • 2016-10-27
      • 2017-09-13
      • 2018-07-28
      • 1970-01-01
      • 2017-05-15
      • 2017-04-20
      • 2019-09-18
      相关资源
      最近更新 更多