created_at
updated_at
tags
toc
headings

Element.toggleAttribute

Intro

非常にシンプルかつミッシングピースだった Element.toggleAttribute という仕様が提案された。

最近になって各ブラウザが一斉に実装を進め、リリースに向けたアナウンスが出始めている。

この仕様について解説する。

Boolean Attributes

Boolean Attribute とは、属性の存在によって真偽となる属性である。

例えば button の disabled を例にとるとこうなる。

button を disabled にする場合は、仕様上は以下の 3 つの書き方がある。

<!-- 属性のみを書く -->
<button id=target disabled>toggle target</button>

<!-- 値を empty string にする -->
<button id=target disabled="">toggle target</button>

<!-- 属性名と同じにする -->
<button id=target disabled=disabled>toggle target</button>

値に true, false などを設定することで有効無効が切り替わるわけではなく、仕様上は許可されていない点に注意したい。

disabled 属性自体は JS から真偽値で操作できる。

target.disabled = true
target.disabled = false

しかし、他の boolean attribute も含め、属性自体を汎用的に操作する場合は以下のようになる。

target.setAttribute("disabled", "");
target.removeAttribute("disabled");

target.setAttribute("disabled", false); // 無効になるわけではない

無効にする場合は、属性自体を消す(omit)という点は、直感に反するところもあるかもしれない。

これをもう少し直感的にするために、引数を boolean にできる API があっても良いのではとして提案されたのが始まりだ。

Element.toggleAttribute

結果的には以下のような API に落ち着いた。

属性名を指定して toggleAttribute を呼べば、 true/false を切り替えられる。

(値は empty string が採用された)

// target = <button id=target>toggle target</button>

target.toggleAttribute("disabled") // => <button id="target" disabled="">toggle target</button>
console.log(target.disabled) // true

target.toggleAttribute("disabled") // => <button id="target">toggle target</button>
console.log(target.disabled) // false

target.toggleAttribute("disabled") // => <button id="target" disabled="">toggle target</button>
console.log(target.disabled) // true

第二引数を指定すると、現在の値に関わらず、第二引数の値に変更する。

// 今が true であれ false であれ true にする
target.toggleAttribute("disabled", true)
console.log(target.disabled) // true

// 今が true であれ false であれ false にする
target.toggleAttribute("disabled", false)
console.log(target.disabled) // false

DEMO

動作するデモを以下に用意した。

Proposal

この機能の提案は 2017/5/23 に以下の issue で行われた。

Consider boolean interface for properties - Issue #461 - whatwg/dom

Boolean 専用の setAttribute が欲しいというところから始まり、議論の末に名前などが代わり 5 月のうちにはおよそ今の形におちついた。

その後 Anne が needs implementer interest というラベルをつけて、そこから一年間は反応がなかった。

先月(2018/6)に入って、 Firefox, Chrome, Edge あたりが positive な反応を示し、同時に DOM の仕様への PR が作られる。

Add toggleAttribute to Element. by jonathanKingston - Pull Request #656 - whatwg/dom

そこから一気に実装が始まった。

Implementation

Firefox は 61 をターゲットに intents を出している

Chrome は intent to implement が出ており canary には入っている。

safari は TP61 に入った

Edge もやっていると思われるが、トラックできるソースは見つからなかった。

Outro

jQuery を始めとするライブラリなどにはよく実装されていたが、標準の範囲においてミッシングピースではあった。

今回は単純な機能なためか、かなりの速さで策定と実装が進み、先月くらいから立て続けにアナウンスが出てきたので、スピード感があったため印象に残っている。