簡體   English   中英

Angular 2:SyntaxError:意外令牌

[英]Angular 2 : SyntaxError: Unexpected token <

我知道這類問題已被提出,我也提到了所有已回答的問題,但我仍然無法解決問題。 當我部署import 'rxjs/add/operator/fromArray';時,將發生此錯誤import 'rxjs/add/operator/fromArray'; 除了這個importObservable.fromArray ,代碼完美無缺。 我正處於角度2.0.0-beta.7

向控制台拋出錯誤

SyntaxError: Unexpected token <(…)
Zone.run                                       @angular2-polyfills.js:1243
zoneBoundFn                                    @angular2-polyfills.js:1220
lib$es6$promise$$internal$$tryCatch            @angular2-polyfills.js:468
lib$es6$promise$$internal$$invokeCallback      @angular2-polyfills.js:480
lib$es6$promise$$internal$$publish             @angular2-polyfills.js:451
lib$es6$promise$$internal$$publishRejection    @angular2-polyfills.js:401
(anonymous function)                           @angular2-polyfills.js:123
Zone.run                                       @angular2-polyfills.js:1243
zoneBoundFn                                    @angular2-polyfills.js:1220
lib$es6$promise$asap$$flush                    @angular2-polyfills.js:262

app.component.ts

   import {Component} from "angular2/core";
   import {Observable} from "rxjs/Rx";
   import 'rxjs/add/operator/map';
   import 'rxjs/add/operator/debounceTime';
   import 'rxjs/add/operator/fromArray';

@Component({
    selector: 'my-app',
    template: ` 
          <input type="text" class="form-control" placeholder="Search...">
          `
   })

export class AppComponent {
constructor(){
    var startDates = [];
    var startDate = new Date();

    for ( var day = -2; day <=2; day++){
        var date = new Date(
            startDate.getFullYear(),
            startDate.getMonth(),
            startDate.getDate() + day);
    }

    startDates.push(date);

    Observable.fromArray(startDates)
        .map(date => {
                     console.log('Getting deal for the date ' + date);
                     return [1, 2, 3];
                     })
        .subscribe(x => console.log(x));

   }
}

的index.html

 <html>
   <head>
      <title>Angular 2 QuickStart</title>
      <link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.css">
    <link rel="stylesheet" href="app/styles.css">
  <!-- 1. Load libraries -->
  <!-- IE required polyfills, in this exact order -->
<script src="node_modules/es6-shim/es6-shim.min.js"></script>
<script src="node_modules/systemjs/dist/system-polyfills.js"></script>
<script src="node_modules/angular2/bundles/angular2-polyfills.js"> </script>
 <script src="node_modules/systemjs/dist/system.src.js"></script>
<script src="node_modules/rxjs/bundles/Rx.js"></script>
<script src="node_modules/angular2/bundles/angular2.dev.js"></script>
<script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/2.0.0/jquery.min.js"></script>
<!-- 2. Configure SystemJS -->
<script>
System.config({
    packages: {
        app: {
            format: 'register',
            defaultExtension: 'js'
        }
    }
});
System.import('app/boot')
        .then(null, console.error.bind(console));
  </script>
</head>

<!-- 3. Display the application -->
  <body>
     <my-app>
      Loading...
     </my-app>
   </body>
  </html>

tsconfig.json

  {
    "compilerOptions": {
    "target": "es5",
    "module": "system",
    "moduleResolution": "node",
    "sourceMap": true,
     "emitDecoratorMetadata": true,
    "experimentalDecorators": true,
    "removeComments": false,
    "noImplicitAny": false
},
  "exclude": [
  "node_modules",
  "typings/main",
  "typings/main.d.ts"
   ]
 }

的package.json

 {
   "name": "angular2-quickstart",
   "version": "1.0.0",
   "scripts": {
   "start": "concurrent \"npm run tsc:w\" \"npm run lite\" ",
   "tsc": "tsc",
   "tsc:w": "tsc -w",
    "lite": "lite-server",
    "typings": "typings",
    "postinstall": "typings install"
   },
    "license": "ISC",
    "dependencies": {
    "angular2": "2.0.0-beta.7",
    "bootstrap": "^3.3.6",
    "es6-promise": "^3.0.2",
    "es6-shim": "^0.33.3",
    "reflect-metadata": "0.1.2",
     "rxjs": "5.0.0-beta.2",
     "systemjs": "0.19.22",
     "zone.js": "0.5.15"
  },
     "devDependencies": {
     "concurrently": "^2.0.0",
     "lite-server": "^2.1.0",
      "typescript": "^1.7.5"
    }
   }

我認為您可以使用“from”運算符而不是“fromArray”運算符:

Observable.from(startDates)
    .map(date => {
      (...)
    });

嘗試從可觀察路徑導入fromArray運算符。

導入'rxjs / add / observable / fromArray';

這是一個有效的例子:

import {Observable} from 'rxjs/Observable'
import 'rxjs/add/operator/map'
import 'rxjs/add/observable/fromArray'

import {Component} from 'angular2/core';

@Component({
    selector: 'my-app',
    template: ``
})
export class AppComponent {
    constructor() {
        Observable.fromArray([1, 2, 3])
            .map(data => "Value = " + data)
            .subscribe(x => console.log(x));
    }
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM