Slide 1

Slide 1 text

Greet(‘Brooklyn JS’)

Slide 2

Slide 2 text

Who this Mu-An Chiou Web Systems Engineer @ GitHub Taiwan #1 GitHub @muan / Twitter @muanchiou

Slide 3

Slide 3 text

Details on The best element in HTML 5. Do @ me.

Slide 4

Slide 4 text

https://www.chromestatus.com/metrics/feature/timeline/popularity/480

Slide 5

Slide 5 text

What

Slide 6

Slide 6 text

What Details

content

Slide 7

Slide 7 text

What Details

content

Slide 8

Slide 8 text

What Details

content

Slide 9

Slide 9 text

What Details

content

Slide 10

Slide 10 text

What details.open = true/false

Slide 11

Slide 11 text

What details.addEventListener(‘toggle’, () => {})

Slide 12

Slide 12 text

Why not this el.addEventListener('click', e => { const thing = document.querySelector(‘.thing’) thing.style.display = ‘none’ })

Slide 13

Slide 13 text

Or this input:check + * { display: block; }

Slide 14

Slide 14 text

Here’s why Semantic

Slide 15

Slide 15 text

Here’s why Accessible

Slide 16

Slide 16 text

Here’s why No JavaScript

Slide 17

Slide 17 text

Here’s why = Interactive on load

Slide 18

Slide 18 text

When

Slide 19

Slide 19 text

When Accordions Popovers Dropdowns …

Slide 20

Slide 20 text

The beginning ! IE 11

Slide 21

Slide 21 text

Dropdown menu

Slide 22

Slide 22 text

Dropdown menu …

Slide 23

Slide 23 text

Dropdown menu

Slide 24

Slide 24 text

Dropdown menu CSS: summary::before

Slide 25

Slide 25 text

Dropdown menu CSS: summary::before + JS: [esc] to close

Slide 26

Slide 26 text

Build status

Slide 27

Slide 27 text

Emoji reactions

Slide 28

Slide 28 text

Also Dialogs!

Slide 29

Slide 29 text

No content

Slide 30

Slide 30 text

… …

Slide 31

Slide 31 text

Focus management Tab trapping Accessibility enhancements Sorry

Slide 32

Slide 32 text

… …

Slide 33

Slide 33 text

EXCITED? Let’s talk browser support —

Slide 34

Slide 34 text

Browser support Desktop 86% / Mobile 95% http://caniuse.com/#search=details

Slide 35

Slide 35 text

Polyfill javan/details-element-polyfill

Slide 36

Slide 36 text

CSS Helpers primer-utilities @ npm

Slide 37

Slide 37 text

<3 HTML

Slide 38

Slide 38 text

GitHub @muan / Twitter @muanchiou Definitely the best element in HTML 5.