首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在角度上的可观测响应上不存在属性映射。

在角度上的可观测响应上不存在属性映射。
EN

Stack Overflow用户
提问于 2016-05-27 11:20:31
回答 2查看 1.2K关注 0票数 3

我试图构建一个角质2应用程序使用类型记录在visual 2015应用程序。我正在使用角释放候选1。

我已经创建了一个risk.service组件,它将为我的视图提供数据。试着用可观察的方法。但是,我在visual studio编辑器中得到了以下错误消息

在可观察的响应上不存在属性映射。

risk.service.ts

代码语言:javascript
复制
import { Injectable } from '@angular/core';
import { IRisk } from './risk';

import { Http, Response } from '@angular/http';
import 'rxjs/Rx'
import {Observable} from 'rxjs/Observable';
import 'rxjs/add/operator/map';

@Injectable()
export class RiskService {
    private _riskUrl = 'www.MyService.com/api/risks';
    constructor(private _http: Http) { }

    getRisks(): Observable<IRisk[]> {
        return this._http.get(this._riskUrl)
            .map((response: Response) => <IRisk[]>response.json());
            }

    }

Systemjs.config.js

代码语言:javascript
复制
(function (global) {

    // map tells the System loader where to look for things
    var map = {
        'app': 'app', // 'dist',
        'rxjs': 'node_modules/rxjs',
        'angular2-in-memory-web-api': 'node_modules/angular2-in-memory-web-api',
        '@angular': 'node_modules/@angular',
        'primeng': 'node_modules/primeng'
    };

    // packages tells the System loader how to load when no filename and/or no extension
    var packages = {
        'app': { main: 'main.js', defaultExtension: 'js' },
        'rxjs': { defaultExtension: 'js' },
        'angular2-in-memory-web-api': { defaultExtension: 'js' },
        'primeng': { defaultExtension: 'js' }

    };

    var packageNames = [
      '@angular/common',
      '@angular/compiler',
      '@angular/core',
      '@angular/http',
      '@angular/platform-browser',
      '@angular/platform-browser-dynamic',
      '@angular/router',
      '@angular/testing',
      '@angular/upgrade',
      '@angular/router-deprecated'
    ];

    // add package entries for angular packages in the form '@angular/common': { main: 'index.js', defaultExtension: 'js' }
    packageNames.forEach(function (pkgName) {
        packages[pkgName] = { main: 'index.js', defaultExtension: 'js' };
    });

    var config = {
        map: map,
        packages: packages
    }

    // filterSystemConfig - index.html's chance to modify config before we register it.
    if (global.filterSystemConfig) { global.filterSystemConfig(config); }

    System.config(config);

})(this);

Package.json

代码语言:javascript
复制
{
  "name": "product-management",
  "version": "1.0.0",
  "author": "Deborah Kurata",
  "description": "Package for the Acme Product Management sample application",
  "scripts": {
    "start": "concurrently \"npm run tsc:w\" \"npm run lite\" ",
    "tsc": "tsc",
    "tsc:w": "tsc -w",
    "lite": "lite-server",
    "typings": "typings",
    "postinstall": "typings install"
  },
  "license": "ISC",
  "dependencies": {
    "@angular/common": "2.0.0-rc.1",
    "@angular/compiler": "2.0.0-rc.1",
    "@angular/core": "2.0.0-rc.1",
    "@angular/http": "2.0.0-rc.1",
    "@angular/platform-browser": "2.0.0-rc.1",
    "@angular/platform-browser-dynamic": "2.0.0-rc.1",
    "@angular/router": "2.0.0-rc.1",
    "@angular/router-deprecated": "2.0.0-rc.1",
    "es6-shim": "^0.35.0",
    "primeng": "^1.0.0-beta.6",
    "primeui": "^4.1.11",
    "reflect-metadata": "0.1.3",
    "rxjs": "5.0.0-beta.8",
    "systemjs": "0.19.26",
    "zone.js": "^0.6.12"
  },
  "devDependencies": {
    "angular-cli": "^1.0.0-beta.0",
    "clang-format": "^1.0.35",
    "codelyzer": "0.0.14",
    "ember-cli-inject-live-reload": "^1.4.0",
    "es6-promise": "3.2.1",
    "jasmine-core": "^2.4.1",
    "jasmine-spec-reporter": "^2.4.0",
    "karma": "^0.13.15",
    "karma-chrome-launcher": "^0.2.3",
    "karma-jasmine": "^0.3.8",
    "protractor": "^3.3.0",
    "ts-node": "^0.5.5",
    "tslint": "^3.6.0",
    "typescript": "^1.8.10",
    "typings": "^0.8.1"
  },
  "repository": {}
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-06-11 06:06:34

您所遇到的问题实际上与TypeScript与外接程序和Intellisense有关,而不是特定的Angular2。这是一个已知的问题,已经修补,并将包括在下一个版本。

替换文件: C:\Program (X86)\ 14.0\Common7\IDE\CommonExtensions\Microsoft\TypeScript\typescriptServices.js

下面的文件。备份后:https://raw.githubusercontent.com/Microsoft/TypeScript/Fix8518/lib/typescriptServices.js

这在技术上是问题的复制(参见Eric的答案):

GitHub问题

票数 2
EN

Stack Overflow用户

发布于 2016-06-10 17:28:16

我认为您可以尝试使用5.0.0-beta.6版本的Rxjs:

代码语言:javascript
复制
"dependencies": {
  "@angular/common": "2.0.0-rc.1",
  "@angular/compiler": "2.0.0-rc.1",
  "@angular/core": "2.0.0-rc.1",
  "@angular/http": "2.0.0-rc.1",
  "@angular/platform-browser": "2.0.0-rc.1",
  "@angular/platform-browser-dynamic": "2.0.0-rc.1",
  "@angular/router": "2.0.0-rc.1",
  "@angular/router-deprecated": "2.0.0-rc.1",
  "es6-shim": "^0.35.0",
  "primeng": "^1.0.0-beta.6",
  "primeui": "^4.1.11",
  "reflect-metadata": "0.1.3",
  "rxjs": "5.0.0-beta.6", // <-----
  "systemjs": "0.19.26",
  "zone.js": "^0.6.12"
},

正如“5分钟快速启动”医生在angular.io网站上所建议的那样。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37482202

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档