angular - 在 dart angular2 的组件中使用 paper-tabs

标签 angular dart dart-polymer

我正在尝试在 dart Angular2 组件中使用聚合物纸标签,但我做不到。下面的代码中我缺少什么?

在以下代码中,index.html 模板中指定的 paper-tabs 工作正常,但 main-app.html 中的 paper-tabs 格式不正确,并且在没有任何适当动画的情况下单击时会消失。

pubspec.yaml

name: tabs_test
version: 0.0.1
description: Test Paper Tabs
environment:
  sdk: '>=1.13.0 <2.0.0'
dependencies:
  angular2: ^2.0.0-beta.13.1
  polymer: ^1.0.0-rc.16
  polymer_elements: ^1.0.0-rc.8
transformers:
- polymer:
    entry_points: web/index.html
- angular2:
    platform_directives:
    - 'package:angular2/common.dart#COMMON_DIRECTIVES'
    - 'package:angular2/common.dart#FORM_DIRECTIVES'
    platform_pipes:
    - 'package:angular2/common.dart#COMMON_PIPES'
    entry_points: web/main.dart

index.html

<!DOCTYPE html>
<html>
  <head>
    <title>Tab Test</title>
    <script defer src="main.dart" type="application/dart"></script>
  </head>
  <body>
    <main-app></main-app>
    <paper-tabs selected="0"> <!-- THESE WORK -->
      <paper-tab>INDEX ITEM ONE</paper-tab>
      <paper-tab>INDEX ITEM TWO</paper-tab>
      <paper-tab>INDEX ITEM THREE</paper-tab>
    </paper-tabs>
  </body>
</html>

main.dart

import 'package:polymer/polymer.dart';
import 'package:angular2/platform/browser.dart';
import 'package:tabs_test/views/main_app/main_app.dart';

main() async {
  await initPolymer();
  bootstrap(MainApp, []);
}

main_app.dart

import 'package:angular2/angular2.dart';
import 'package:polymer_elements/paper_tabs.dart';
import 'package:polymer_elements/paper_tab.dart';

@Component(selector: 'main-app',
    templateUrl: 'main_app.html',
    providers: const[],
    directives: const []
)
class MainApp {
  MainApp() { }
}

main_app.html

<paper-tabs selected="0"> <!-- THESE DO NOT WORK -->
  <paper-tab>MA ITEM ONE</paper-tab>
  <paper-tab>MA ITEM TWO</paper-tab>
  <paper-tab>MA ITEM THREE</paper-tab>
</paper-tabs>

最佳答案

像往常一样,当 Polymer 与 Angular2 一起使用时,您需要启用完整阴影 DOM

将其添加到其他脚本标记之前

<script src="packages/web_components/webcomponents.js"></script>
<script>
   /* this script must run before Polymer is imported */
   window.Polymer = {
     dom: 'shadow',
     lazyRegister: true
   };
 </script>

有关此主题的更多详细信息,请参阅 https://dart.academy/dart-angular-2-and-polymer-together/

Repo project on GitHub

关于angular - 在 dart angular2 的组件中使用 paper-tabs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36720611/

相关文章:

dart - 如何在文档中查找元素的大小

dart - 带有聚合物运行时错误的Dart2Js

javascript - 为什么 Angular 中基于 jQuery token 的集成不起作用?

html - 如何使用插值来设置属性选择器?

AngularJS v1x。未在混合 angular-cli 应用程序中加载

angular - 如何清除现有模型,或者有没有办法重新初始化 Monaco Editor

multithreading - Dart是否会在多核环境中并行执行隔离?

flutter - 在 channel plugins.flutter.io/image_picke 上找不到方法 pickImage 的实现

dart - 本地 Dart 库的使用

dart - Dart 。在使用聚合物的新MAP中,为什么会得到 “too many elements”?