dart - 以编程方式创建聚合物元素

标签 dart dart-polymer

我有一个现有的应用程序(使用canvas标签的游戏​​),我想尝试使用PolymerDart为它创建UI元素(例如设置屏幕,与游戏中角色的对话框交互之类的东西)。

我正在尝试使基本点击计数器示例正常工作。我的index.html看起来像:

<html>
  <head>
    <title>PraxisClient</title>
    <script async type="application/dart" src="app.dart"></script>
    <script async src="packages/browser/dart.js"></script>
    <script src="packages/web_components/platform.js"></script>
    <script src="packages/web_components/dart_support.js"></script>
    <link rel="import" href="app/elements/click_counter.html">
  </head>
  <body>
    <div id="ui">
    </div>
  </body>
</html>

在我的应用程序中,我尝试使用以下元素创建元素:

querySelector('#ui').children.add(new Element.tag('click-counter'));

点击计数器代码都与https://www.dartlang.org/polymer/#data-binding上给出的示例相同

<link rel="import" href="../packages/polymer/polymer.html">
<polymer-element name="click-counter">
  <template>
    <button on-click="{{increment}}">Click Me</button>
    <p>You clicked the button {{count}} times.</p>
  </template>
  <script type="application/dart" src="click_counter.dart"></script>
</polymer-element>

import 'package:polymer/polymer.dart';
import 'dart:html';

@CustomTag('click-counter')
class ClickCounterElement extends PolymerElement {
  @observable int count = 0;

  ClickCounterElement.created() : super.created();

  void increment(Event e, var detail, Node target) {
    count += 1;
  }
}

我得到的错误是:

URL必须由Dart主脚本导入:click_counter.dart

但是,即使将click_counter.dart导入我的应用程序中似乎也无济于事,我只是在dom中看到该标签,而没有执行任何代码。

如果我向元素(<polymer-element noscript>)添加一个“noscript”属性,那么我会看到显示了模板(但未执行任何代码)。

最佳答案

pubspec.yaml中,聚合物变压器配置的每个入口页面都需要一个入口

transformers:
- polymer:
    entry_points:
    - web/index.html

缺少此配置时,pub serve应该创建一个警告。

<html>
  <head>
    <title>PraxisClient</title>
    <!-- <script src="packages/web_components/platform.js"></script>
         not necessary anymore with Polymer >= 0.14.0 -->
    <script src="packages/web_components/dart_support.js"></script>
    <link rel="import" href="app/elements/click_counter.html">
  </head>
  <body>
    <div id="ui">
    </div>
    <!-- moved down and removed the `async` attribute 
         these things get modified anyway when you run `pub build`
         if you want to have customized behavior you need to do it
         in a custom transformer or in the build output (as far as I know) -->
    <script type="application/dart" src="app.dart"></script>
    <script src="packages/browser/dart.js"></script>
  </body>
</html>

更改

<link rel="import" href="../packages/polymer/polymer.html">



<link rel="import" href="../../packages/polymer/polymer.html">

关于dart - 以编程方式创建聚合物元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25591386/

相关文章:

android - Flutter:FlutterFirebaseInstanceIDService.java 使用或覆盖已弃用的 API

dart - 将 Assets 目录移到Jekyll博客文章的dart项目中

Dart:无法访问动态设置的元素 ID

html - polymer 网格布局中的最后一行

svg - 在聚合物元件内部使用SVG

dart - 写入与添加之间的区别

flutter - 迭代时从列表中获取索引

dart - Dart Map语法: putIfAbsent ('FirstKey' ,()=> 1);什么是: ()?

node.js - custom_element_apigen:导入纸张数据表到Dart时出错

dart - 我怎么知道聚合物 Dart 何时完全初始化?