dart系列之:HTML的专属领域,除了javascript之外,dart也可以
yuyutoo 2025-05-28 21:26 6 浏览 0 评论
简介
虽然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/最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!
欢迎关注我的公众号:「程序那些事」,懂技术,更懂你!
相关推荐
- Python+selenium自动化之selenium常用API
-
前面的几十篇文章介绍了selenium的常用的API的用法,但是这些仅仅是API的一小部分,大家可以去selenium官网获取查看https://python-selenium-zh.readthed...
- 如何用英文写电子邮件?英文的邮件格式怎么写?
-
电子邮件可以说是现代社会中人们交流沟通的重要工具之一,我们在社交、求学、工作中都需要用到邮件。如何写一封合适的英文电子邮件就是我们今天的主题。首先,请看下面这封邮件:这是不是就是很多小伙伴的邮件的样子...
- 如何删除Linux文件夹中除某些扩展名之外的所有文件?
-
假设你有一个名为data的文件夹,里面包含各种类型的文件,例如:...
- 手把手教你实现振动记录器
-
概述本文只涉及实现及代码讲解,不涉及具体技术的讲解,并尽量每一行代码都有详尽的注释,先实现,后积累。前端-入门级教程-简易振动记录器本文教大家实现一个简易的振动记录器。包括短振动、长振动、振...
- UG NX 出图技巧
-
UGNX出图技巧A、出工程图时,如何屏蔽掉多余的轮廓线?方法一:选中要修改的视图---按右键---选择“型式”--出现“查看形式”对话框---选择“光滑边”栏---把“光滑边”的...
- 利用forms表单组件进行表单校验
-
###利用forms表单组件进行表单校验,完成用户名,密码,确认密码,邮箱功能的校验该作业包含了下面的知识点:error_messages,label,required,invalid,局部钩子函数...
- 关于"must"的这些用法,你“必须”知道!
-
1mustbe\mustdo用于现在时Hekeepslookingatyou,hemustlikeyou.他一直在看你,他一定是喜欢你吧Shelookssobeautif...
- vue confirm弹窗提示确认,修改提示的字体颜色
-
1.日常写法this.$confirm(context,"提示",{confirmButtonText...
- 战旗TV悬赏令:守望先锋重金求天梯英雄
-
终于等到你!国服守望先锋持续一周的压力测试即将到来,蓄势待发的你是否已经热血沸腾?战旗TV发布天梯英雄悬赏令,直播冲击国服天梯段位就可获得大量奖励,赶快加入直播间的守望者行列!活动专区:http://...
- dart系列之:HTML的专属领域,除了javascript之外,dart也可以
-
简介虽然dart可以同时用作客户端和服务器端,但是基本上dart还是用做flutter开发的基本语言而使用的。除了andorid和ios之外,web就是最常见和通用的平台了,dart也提供了对HTML...
- 直播!去东新路寻找“夜杭州”的烟火气,人气餐厅美食福利放送中
-
APP中打开,直接点击图片进入直播;微信中打开稿件,保存直播海报,打开淘宝APP可以收看直播淘宝直播地址:h5.m.taobao.com/taolive/video.html?userId=41258...
- 深入浅出序列化(1)——JDK序列化和Hessian序列化
-
我之前在《聊一聊RPC》中曾提过什么是序列化和反序列化,当时有说过之后要单独抽出一期来详细聊聊序列化,没想到这一拖竟然拖了一年多,现在来把这个坑补上。由于篇幅较长,本文先主要介绍两种常见的序列化方式...
- Web前端开发,HTML超链接标签,不懂的可以学习一下
-
一、什么是HTML的超链接大家平时浏览的网页中都可以找到链接。点击链接就可以从一个页面跳转到另一个页面。HTML超链接可以是一个字,一个词,或者一组词,也可以是一幅图像。可以点击这些内容来跳转到新的文...
- TypeScript 终极初学者指南
-
在过去的几年里TypeScript变得越来越流行,现在许多工作都要求开发人员了解TypeScript...
- QStyle
-
一、描述QStyle类是一个抽象基类,它封装了GUI的外观。样式也可以作为插件使用。Qt的内置小部件使用QStyle来执行几乎所有的绘图,确保它们看起来与等效的原生小部件完全一样。下图显示...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
推荐7个模板代码和其他游戏源码下载的网址
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)