Подтвердить что ты не робот

Angular2 Селектор не соответствует элементам вложенных компонентов

У меня есть два вложенных @Components en angular 2. Вид выглядит просто отлично, но он всегда выдает ошибку javascript в первый раз. Вот мой код в Typescript.

Приложение HTML:

<body>
    <my-app>loading...</my-app>
</body>

Компонент приложения:

import {bootstrap, Component} from 'angular2/angular2';
import {CanvasComponent} from "./CanvasComponent";

@Component({
  selector: 'my-app',
  template: `
      <h1>{{title}}</h1>
      <h2>My Games</h2>
      <div>
        <my-canvas></my-canvas>
      </div>
  `,
  directives: [CanvasComponent]
})

class AppComponent {
}

bootstrap(AppComponent);

Компонент холста:

import {bootstrap, Component, View} from 'angular2/angular2';

@Component({
  selector: 'my-canvas'
})

@View({
  template: `
  <div>
    <span>Balls:</span>
    <div>{{canvas.length}}</div>
  </div>
  `
})

export class CanvasComponent {
  canvas = [1,2,3];
}

bootstrap(CanvasComponent);

Ошибка:

EXCEPTION: The selector "my-canvas" did not match any elements
4b9b3361

Ответ 1

Удалите bootstrap(CanvasComponent) из вашего файла CanvasComponent. Он пытается перезагрузить приложение во второй раз, используя CanvasComponent в качестве корня и ищет элемент my-canvas в вашем приложении HTML. Конечно, он не может его найти.

Ответ 2

Я исправил проблему, изменив имя в index.html, вы должны быть уверены, что тег в index.html является тем же селектором, что и в основном компоненте.

    <html>
      <head>
        <title>Angular 2 QuickStart</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <link rel="stylesheet" href="stylesheets/styles.css">
        <!-- 1. Load libraries -->
         <!-- Polyfill(s) for older browsers -->
        <script src="node_modules/core-js/client/shim.min.js"></script>
        <script src="node_modules/zone.js/dist/zone.js"></script>
        <script src="node_modules/reflect-metadata/Reflect.js"></script>
        <script src="node_modules/systemjs/dist/system.src.js"></script>
        <!-- 2. Configure SystemJS -->
        <script src="systemjs.config.js"></script>
        <script>
        System.import('app').catch(function(err){ console.error(err); });
        </script>
      </head>
      <!-- 3. Display the application -->

      <body>
        <my-app>Loading...</my-app> <!-- THIS TAG SHOULD BE THE SAME THAT THE SELECTOR IN THE MAIN COMPONENT -->
      </body>
    </html>

<!-- end snippet -->

  </body>
</html>

Ответ 3

В моем index.html мне не хватало

<base href="/">

Таким образом, минимум, который должен быть там, есть

<!doctype html>
<head>
    <base href="/">
</head>
<body>
    <your-selector></your-selector>
</body>
</html>