Tab panel component with the following features:
html
html
and css
html
, css
and js
js
polyfills are not neededRequirements:
npm install @oom/tab
npm install @webcomponents/custom-elements
Let’s start with the following html code:
<my-tabs role="region">
<ul role="tablist">
<li role="presentation">
<a href="#section1" role="tab" id="tab1" aria-selected="true">
Section 1
</a>
</li>
<li role="presentation">
<a href="#section2" role="tab" id="tab2">
Section 2
</a>
</li>
<li role="presentation">
<a href="#section3" role="tab" id="tab3">
Section 3
</a>
</li>
</ul>
<section id="section1" aria-labelledby="tab1" role="tabpanel">
Content section 1
</section>
<section id="section2" aria-labelledby="tab2" role="tabpanel">
Content section 2
</section>
<section id="section3" aria-labelledby="tab3" role="tabpanel">
Content section 3
</section>
</my-tabs>
Use css to define the tab panel appearance:
/* This makes the tabs works without javascript */
section:not(:target) {
display: none;
}
[role="tablist"] {
display: flex;
list-style: none;
padding: 0;
}
And finally use javascript for a complete experience:
import Tab from "./tab/tab.js";
//Register the custom element
customElements.define("my-tabs", Tab);
This is a custom element that extends HtmlElement
, so it innerit the same api
of a standard html element with the following additions:
//Select the element
const element = document.querySelector("my-tabs");
//Change the tab state
element.setState("#section2");
//Get the currently selected tabpanel element
console.log(element.panel);
//Get the currently selected tab element
console.log(element.tab);
To run the demo locally, just clone this repository, enter in the directory and execute:
npm install
npm start
You should see something in the following urls:
http://localhost:8080/demo
http://localhost:8080/tests