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 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/
最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
聊聊自定义SPI如何与sentinel整合实现熔断限流
前言 之前我们聊了一下聊聊如何实现一个带有拦截器功能的SPI。当时我们实现的核心思路是利用了责任链+动态代理。今天我们再聊下通过动态代理如何去整合sentinel实现熔断限流 前置知识 alibaba sentinel简介 Sentinel 是面向分布式服务架构的流量控制组件,主要以流量为切入点,从限流、流量整形、熔断降级、系统负载保护、热点防护等多个维度来帮助开发者保障微服务的稳定性。 sentinel工作流程 sentinel关键词 资源 + 规则 sentinel实现模板套路 Entry entry = null; // 务必保证 finally 会被执行 try { // 资源名可使用任意有业务语义的字符串,注意数目不能太多(超过 1K),超出几千请作为参数传入而不要直接作为资源名 // EntryType 代表流量类型(inbound/outbound),其中系统规则只对 IN 类型的埋点生效 entry = SphU.entry("自定义资源名"); // 被保护的业务逻辑 // do something... } catch (BlockException ex) { /...
- 下一篇
CloudCanal-2.0 自定义代码实时加工能力(自定义实时ETL)说明与介绍
简介 CloudCanal 2.0中我们将迎来一项重磅更新——自定义代码实时加工能力。自定义代码实时加工允许用户使用Java语言编写自定义的数据行处理逻辑,然后将代码jar包上传CloudCanal平台后,数据同步任务在执行全量、增量时会自动应用用户的自定义处理逻辑,然后再写入对端数据源。 应用场景 自定义代码实时加工是一种非常灵活的实时数据加工手段,在自定义代码中用户可以进行跨实例查询、微服务调用、缓存查询等各种操作,然后对实时接收到的数据行进行编辑。数据编辑支持用户自定义新增行、修改行、删除行。其中修改行支持用户新增列、修改列、删除列。自定义代码实时加工可用于以下场景: 数据清洗 构建实时数仓、数据湖以及进行数据治理时都需要对数据进行清洗,涉及数据过滤、加工、标准化。在这个过程中,用户可以上传自定义代码,引入自己的一些企业内部数据标准化处理的二方包或者调用一些微服务或者反查数据库对收到的实时数据进行编辑。这样同步到对端后,就是直接已经清洗好的数据。 宽表构建 数据同步到数仓、数据湖中时,必然面临的一个问题就是处理多个源端关联表的关系,引入自定义代码,可以很容易的来处理这些关系,生成...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS关闭SELinux安全模块
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS8编译安装MySQL8.0.19
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- CentOS7,CentOS8安装Elasticsearch6.8.6