web - 如何在 dart 中创建自定义元素?

标签 web dart element

我正在尝试在 dart 中创建一个自定义元素。它应该只包含 2 个按钮。它从未真正通过施工过程......我做错了什么?

class GraphButton extends Element {
  factory GraphButton() => new Element.tag('GraphButton');
  ButtonElement colorBtn;
  ButtonElement removeBtn;

  GraphButton.created() : super.created() {

  }

  void setup(String buttonText) {
    text = buttonText;
    //initialize color btn
    colorBtn
      ..id = 'colorBtn' + text
      ..text = "colorSelector"
      ..onClick.listen(
          (var e) => querySelector('#output').text = id + 'button clicked!');

//initialize remove button
    removeBtn
      ..id = 'removeBtn' + text
      ..text = 'X'
      ..onClick.listen(
          (var e) => this.remove());

  //add to DOM
  this.children
  ..add(colorBtn)
  ..add(removeBtn);
  }
}

最佳答案

您的代码中存在一些问题。

  • 自定义元素需要遵循命名规则,它们需要有一个 -以他们的名义
  • 元素需要注册才能让浏览器实例化它们
  • setup(...)您添加的方法没有被调用,因此没有将标题添加到按钮
  • 自定义元素需要扩展 HtmlElement

  • DartPad example

    也可以看看:
  • Registering custom element in Dart lang
  • extendTag in Dart custom element
  • 关于web - 如何在 dart 中创建自定义元素?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37083112/

    相关文章:

    html - 使用图像链接时标题导航栏消失

    python - 使用 python 正则表达式提取列表中的元素

    html - 如果在另一个目录中,404 将不会加载图像

    html - 如何针对 Snap(Windows 中的多窗口模式)优化网站?

    html - 为什么上面的div向左浮动时div元素不向上移动?

    dart - 访问继承的小部件时在 null 上调用了 Getter

    recursion - 多个可滚动小部件的滚动同步

    dart - flutter 垂直视口(viewport)无界高度错误

    jquery - 在动态生成的列表中选择列表元素

    javascript - 从数组中删除元素(拼接)