文章目錄
- 簡介
- DOM操作
- CSS操作
- 處理事件
- 總結
簡介
雖然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/
最通俗的解讀,最深刻的干貨,最簡潔的教程,眾多你不知道的小技巧等你來發現!
歡迎關注我的公眾號:「程式那些事」,懂技術,更懂你!
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/375931.html
標籤:其他
