日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

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

發布時間:2024/2/28 javascript 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 dart系列之:HTML的专属领域,除了javascript之外,dart也可以 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 簡介
  • 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:

changeblurkeyDownkeyUpmouseDownmouseUp

總結

以上就是Dart對html的支持。

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

最通俗的解讀,最深刻的干貨,最簡潔的教程,眾多你不知道的小技巧等你來發現!

歡迎關注我的公眾號:「程序那些事」,懂技術,更懂你!

總結

以上是生活随笔為你收集整理的dart系列之:HTML的专属领域,除了javascript之外,dart也可以的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。