【发布时间】:2022-03-29 21:01:09
【问题描述】:
我正在使用Bulma CSS 在 Svelte 中创建一个导航组件,并且我希望在 class:is-active 为 true 时将每个导航栏项设置为粗体。我目前所做的如下:
<script>
import {onMount} from 'svelte';
let segment;
onMount(() => {
const linkOne = document.getElementById("linkOne");
const linkTwo = document.getElementById("linkTwo");
const linkThree = document.getElementById("linkThree");
const linkFour = document.getElementById("linkFour");
const linkFive = document.getElementById("linkFive");
linkOne.addEventListener('focusin', (event) => {
event.target.style["font-weight"] = 'bold';
});
linkOne.addEventListener('blur', (event) => {
event.target.style["font-weight"] = 'normal';
});
linkTwo.addEventListener('focusin', (event) => {
event.target.style["font-weight"] = 'bold';
});
linkTwo.addEventListener('blur', (event) => {
event.target.style["font-weight"] = 'normal';
});
linkThree.addEventListener('focusin', (event) => {
event.target.style["font-weight"] = 'bold';
});
linkThree.addEventListener('blur', (event) => {
event.target.style["font-weight"] = 'normal';
});
linkFour.addEventListener('focusin', (event) => {
event.target.style["font-weight"] = 'bold';
});
linkFour.addEventListener('blur', (event) => {
event.target.style["font-weight"] = 'normal';
});
linkFive.addEventListener('focusin', (event) => {
event.target.style["font-weight"] = 'bold';
});
linkFive.addEventListener('blur', (event) => {
event.target.style["font-weight"] = 'normal';
});
});
</script>
<nav class="navbar" role="navigation" aria-label="main navigation">
<div class="navbar-brand">
<a href="/" class="navbar-item">
</a>
</div>
<div class="nav-menubar">
<div class="navbar-menu">
<a id="linkOne" href="/" class="navbar-item" class:is-active={segment === undefined}>LinkOne</a>
<a id="linkTwo" href="/linkTwo" class="navbar-item" class:is-active={segment === "linktwo"}>LinkTwo</a>
<a id="linkThree" href="/linkThree" class="navbar-item" class:is-active={segment === "linkthree"}>LinkThree</a>
<a id="linkFour" href="/linkFour" class="navbar-item" class:is-active={segment === "linkfour"}>LinkFour</a>
<a id="linkFive" href="/linkFive" class="navbar-item" class:is-active={segment === "linkfive"}> LinkFive</a>
</div>
</div>
</nav>
在 Firefox(81.0) 上,这会导致链接在焦点上变为粗体,但是当切换到另一个链接并返回时,相同的链接不会变为粗体,除非单击两次。另外,我不确定这是为这些组件设置样式的最佳方式。有人可以提出更好的方法吗?
【问题讨论】: