我基本上是制作Windows XP主题的作品集,但很困惑在选项卡中添加选项卡。我正在学习教程(https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/Tab_Role),而我的问题是,当我调用document.querySelectorAll('[role =“ tab”]')时,我一无所获。使用querySelector()返回null。
我以为可能是因为在打开模式之前尚未创建选项卡,但即使那样,事件侦听器是否也不应在每次向DOM中添加内容时进行检查?也许范围是错误的,但是当我将其放入渲染器或类中的任何地方时,会遇到一些错误。
这是我的组件:
import React, { Component } from "react";
import ReactDOM from "react-dom";
import "xp.css/dist/XP.css";
import Draggable from 'react-draggable';
class AboutMeModal extends Component {
render() {
return (
<Draggable
axis="both"
handle=".tabs"
defaultPosition={{x: 40, y: -80}}
position={null}
grid={[25, 25]}
scale={1}
onStart={this.handleStart}
onDrag={this.handleDrag}
onStop={this.handleStop}>
<section className="tabs" style={{width:'calc(99%)'}}>
<menu role="tablist" aria-label="Sample Tabs">
<button id="tab-1" role="tab" aria-selected="true" aria-controls="tab-A" tabIndex="0">Tab A</button>
<button id="tab-2" role="tab" aria-selected="false" aria-controls="tab-B" tabIndex="-1">Tab B</button>
<button id="tab-3" role="tab" aria-selected="false" aria-controls="tab-C" tabIndex="-1">Tab C</button>
</menu>
<article role="tabpanel" id="tab-A" aria-labelledby="tab-1">
<h3>Tab Content</h3>
<p>
You create the tabs, you would use a <code>menu role="tablist"</code> element then for the tab titles you use a <code>button</code> with the <code>aria-controls</code> parameter set to match the relative <code>role="tabpanel"</code>'s element.
</p>
<p>
Read more at <a href="https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/Tab_Role" target="_blank">MDN Web docs - ARIA: tab role</a>
</p>
</article>
<article role="tabpanel" id="tab-B" aria-labelledby="tab-2" hidden>
<h3>More...</h3>
<p>This tab contains a GroupBox</p>
</article>
<article role="tabpanel" id="tab-C" aria-labelledby="tab-3" hidden>
<h3>Tab 3</h3>
<p>Lorem Ipsum Dolor Sit</p>
</article>
</section>
</Draggable>
);
}
};
export default AboutMeModal;
window.addEventListener("DOMContentLoaded", () => {
console.log("event listener added");
const tabs = document.querySelectorAll('[role="tab"]'); //I never get the list of
//tabs back
const tabList = document.querySelector('[role="tablist"]');
// Add a click event handler to each tab
tabs.forEach(tab => {
console.log("here"); //my code never reaches here!
tab.addEventListener("click", changeTabs);
});
});
function changeTabs(e) {
console.log("change tabs");
const target = e.target;
const parent = target.parentNode;
const grandparent = parent.parentNode;
// Remove all current selected tabs
parent
.querySelectorAll('[aria-selected="true"]')
.forEach(t => t.setAttribute("aria-selected", false));
// Set this tab as selected
target.setAttribute("aria-selected", true);
// Hide all tab panels
grandparent
.querySelectorAll('[role="tabpanel"]')
.forEach(p => p.setAttribute("hidden", true));
// Show the selected panel
grandparent.parentNode
.querySelector(`#${target.getAttribute("aria-controls")}`)
.removeAttribute("hidden");
}
DOMContentLoaded
仅在浏览器知道HTML的基本结构时才触发一次。初始加载后再也不会调用它。您应将事件直接挂在按钮选项卡上:
<button id="tab-1" onClick={changeTabs} role="tab" aria-selected="true" aria-controls="tab-A" tabIndex="0">Tab A</button>
<button id="tab-2" onClick={changeTabs} role="tab" aria-selected="false" aria-controls="tab-B" tabIndex="-1">Tab B</button>
<button id="tab-3" onClick={changeTabs} role="tab" aria-selected="false" aria-controls="tab-C" tabIndex="-1">Tab C</button>