简介

尽管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/

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

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