<!-- ラジオボタン部分 (例) -->
<div class="lang_btn__wrap">
<label>
<input type="radio" name="lang" class="btn_lang" id="jp" checked> JP
</label>
<span> / </span>
<label>
<input type="radio" name="lang" class="btn_lang" id="en"> EN
</label>
</div>
<script>
// 言語表示を再適用する関数
function applyLanguageShow() {
const checkedLang = document.querySelector('input[type="radio"].btn_lang:checked');
if (checkedLang) {
// 一旦全ての言語要素から .show を削除
document.querySelectorAll('.jp, .en').forEach(el => el.classList.remove('show'));
// 現在選択されている言語に対応する要素に .show を追加
document.querySelectorAll('.' + checkedLang.id).forEach(el => el.classList.add('show'));
}
}
document.addEventListener('DOMContentLoaded', function() {
// ページロード時に適用
applyLanguageShow();
// ラジオボタンの変更時に適用
document.querySelectorAll('input[type="radio"].btn_lang').forEach(btn => {
btn.addEventListener('change', function() {
applyLanguageShow();
});
});
// 例:select の変更時にも再適用する(select が更新される場合)
document.querySelectorAll('select[name="classcategory_id1"], select[name="classcategory_id2"]').forEach(sel => {
sel.addEventListener('change', function() {
// DOM更新後に少し遅延させて再適用する
setTimeout(applyLanguageShow, 100);
});
});
});
</script>
<style>
.lang_btn__wrap{
position: fixed;
right:2%;
top: 1rem;
display: flex;
align-items: center;
gap: 0.25em;
}
.lang_btn__wrap label{
display:block;
}
label:has(:checked){
font-size: 0.75em;
padding-inline: 0.125em;
color:#bbb;
text-decoration: underline;
}
.jp,.en{
display:none !important;
}
.jp.show,.en.show{
display:block !important;
}
@media (max-width:768px){
.lang_btn__wrap{
right: 5.5%;
top: 7rem;
}
}
</style>