乐趣区

关于dart:dart系列之HTML的专属领域除了javascript之外dart也可以

简介

尽管 dart 能够同时用作客户端和服务器端,然而基本上 dart 还是用做 flutter 开发的根本语言而应用的。除了 andorid 和 ios 之外,web 就是最常见和通用的平台了,dart 也提供了对 HTML 的原生反对,这个反对就是 dart:html 包。

dart:html 提供了对 DOM 对象的各种有用的操作和对 HTML5 API 的反对。这样咱们能够间接应用 dart 来操作 HTML。

除了 DOM 之外,dart:html 还能够对 css 进行操作, 应用 dart:html 也非常简单:

import 'dart:html';

DOM 操作

对于 DOM 操作来说,首先是须要找到这个元素。

dart 提供了 querySelector() 和 querySelectorAll() 办法,能够依据 ID, class, tag, name 或者这些元素的汇合来进行查找。

同样都是 query 办法,两者的不同在于,querySelector 只返回找到的第一个元素,而 querySelectorAll 返回找到的所有元素。

所以 querySelector 返回的是一个 Element, 而 querySelectorAll 返回的是一个汇合 List<Element>。

Element idElement = querySelector('#someId')!;

Element classElement = querySelector('.some-class')!;

List<Element> divElements = querySelectorAll('div');

List<Element> textInputElements = querySelectorAll('input[type="text"]',);

List<Element> specialElement = querySelectorAll('#someId div.class');

下面就是咱们查找 DOM 中元素的操作。找到之后,就能够对这些元素进行操作了。

dart 应用 Element 来示意 DOM 中的元素。对于每个 Element 来说,都领有 classes, hidden, id, style, 和 title 这些属性。

如果 Element 中并没有要设置的属性,则能够应用 attributes, 如下:

elem.attributes['someAttribute'] = 'someValue';

当然对应某些非凡的 Element,会有 Element 对应的子类与之绑定。

比方对于一个 a 标签来说,如下所示:

<a id="name" href="/name/detail"> 详情 </a>

a 标签对应的是 dart 中的 AnchorElement 元素。

如果要扭转 a 标签的 href 值,能够这样:

var anchor = querySelector('#name') as AnchorElement;
anchor.href = 'http://www.flydean.com';

还能够增加、替换或者删除对应的节点:

querySelector('#id')!.nodes.add(elem);
querySelector('#id')!.replaceWith(elem);
querySelector('#id')?.remove();

下面咱们应用了一个非凡的运算符,感叹号,示意的是将一个可为空的类型转换成为不为空的类型。

CSS 操作

CSS 实际上就是 element 中的 class,当咱们获取到 element 之后,就能够调用他的 classes 字段,而后对 CSS 进行解决。

elem.classes 返回的是一个 list, 咱们能够向其增加或者删除对应的 class。

var name = querySelector('#id')!;
name.classes.add('redline');

有 class 当然是最好了,class 也是咱们举荐的写法。然而有时候还是须要间接在 element 中增加 style, 如下所示:

name.style
  ..fontWeight = 'bold'
  ..fontSize = '3em';

处理事件

和 DOM 的交互就是各种事件, 向 element 中增加 event, 能够应用 element.onEvent.listen(function).

比方咱们能够增加 click 事件:

querySelector('#id')!.onClick.listen((e) {// do something});

上面是罕用的一些 event:

    change
    blur
    keyDown
    keyUp
    mouseDown
    mouseUp

总结

以上就是 Dart 对 html 的反对。

本文已收录于 http://www.flydean.com/20-dart-html/

最艰深的解读,最粗浅的干货,最简洁的教程,泛滥你不晓得的小技巧等你来发现!

欢送关注我的公众号:「程序那些事」, 懂技术,更懂你!

退出移动版