2021・05・26
*クリックで開閉するアコーディオンメニューです*
シンプルですが、大項目に付属している「 ▼ 」マークがメニューの開閉に合わせて回転したり、子メニューのマウスオーバー時に背景色とフォントサイズが変わったりなど、ちょっとした工夫も入れています。
使用機能:CSS・JavaScript
上記のサンプルコードを掲載しています。学習用としてご自由にコピペしてお使い下さい。(※スクロールできます)
HTML・CSS・JavaScript
<!DOCTYPE html>
<html lang="ja" dir="ltr">
<head>
<meta charset="utf-8">
<title></title>
<style>
.samplemenu {
font-family:"游ゴシック体 Medium","游ゴシック体","游ゴシック Medium","Yu Gothic","YuGothic",sans-serif;
padding-inline-start: 0;
width:70%;
margin: 1rem auto;
}
.samplemenu h1 {
margin: 1.5rem;
}
.samplemenu ul {
padding-inline-start: 0;
margin-block-start:0;
margin-block-end:0;
list-style: none;
cursor: pointer;
}
.samplemenu ul li:not(:first-child) {
font-size: .8rem;
background-color: lightblue;
border-bottom: dashed thin blue;
transition: all .4s;
}
.samplemenu ul li:first-child {
font-size: 1rem;
padding: .5rem;
background-color: darkblue;
color: white;
}
.samplemenu ul li:last-child{
border-bottom: none;
}
.samplemenu ul li:not(:first-child):hover {
background-color: rgba(173, 215, 230, 0.52);
font-size: 1rem;
}
.samplesankaku {
display:inline-block;
transform: rotate(-90deg) scale(.5);
transition: all .4s;
}
.samplesankakuactive {
display:inline-block;
transform: rotate(0deg) scale(.5);
transition: all .4s;
}
.samplehide1 {
opacity: 0;
visibility: hidden;
height: 0;
}
.samplehide2 {
opacity: 0;
visibility: hidden;
height: 0;
}
.sampleactive {
opacity: 1;
visibility: visible;
display: flex;
align-items: center;
height: 1.5rem;
padding: .5rem;
}
</style>
</head>
<body>
<menu class="samplemenu">
<h1 style="font-family:'游ゴシック体 Medium','游ゴシック体','游ゴシック Medium','Yu Gothic','YuGothic',sans-serif;">メニュー項目</h1>
<ul>
<li id="samplemenu1"><span class="samplesankaku samplesankaku1">▼</span>MAIN MENU</li>
<li class="samplehide1">HOME</li>
<li class="samplehide1">ABOUT</li>
<li class="samplehide1">CONTACT</li>
</ul>
<ul>
<li id="samplemenu2"><span class="samplesankaku samplesankaku2">▼</span>お知らせ</li>
<li class="samplehide2">最新ニュース</li>
<li class="samplehide2">お知らせ一覧</li>
</ul>
</menu>
<script>
{
const menu1 = document.getElementById('samplemenu1');
const samplesankaku1 = document.querySelector('.samplesankaku1');
const samplehidemenus1 = document.querySelectorAll('.samplehide1');
menu1.addEventListener('click',function (event) {
for (const samplehidemenue1 of samplehidemenus1) {
samplehidemenue1.classList.toggle('samplehide1');
samplehidemenue1.classList.toggle('sampleactive');
};
samplesankaku1.classList.toggle('samplesankakuactive');
});
const menu2 = document.getElementById('samplemenu2');
const samplesankaku2 = document.querySelector('.samplesankaku2');
const samplehidemenus2 = document.querySelectorAll('.samplehide2');
menu2.addEventListener('click',function (event) {
for (const samplehidemenue2 of samplehidemenus2) {
samplehidemenue2.classList.toggle('samplehide2');
samplehidemenue2.classList.toggle('sampleactive');
};
samplesankaku2.classList.toggle('samplesankakuactive');
});
}
</script>
</body>
</html>