gpt4 book ai didi

javascript - 单击按钮切换 Font Awesome 类

转载 作者:太空狗 更新时间:2023-10-29 15:24:40 26 4
gpt4 key购买 nike

我在这个 jsfiddle 中有代码,我希望字体很棒的图标在使用 javascript 单击按钮时发生变化,但它似乎不起作用。我是 javascript 的新手,所以如果这是一个愚蠢的问题,请原谅我。

HTML

<button id="favBtn" onclick="fav();">
<i id="favIcon" class="fa fa-star-o"></i>&nbsp;Favourite
</button>

Javascript

function fav() {
document.getElementById("favIcon").toggleClass('fa-star-o fa-star');
}

最佳答案

使用 jQuery 时,您永远不需要使用内联属性 eventHandler。

onclick=

  • Demo 1 使用 jQuery .toggleClass()

  • Demo 2 使用 JavaScript .classList.toggle()

  • Demo 3 使用CSS :checked伪类

将 v4 更新为 v5:转到 Start | Font Awesome .还有一些类(class)变化。请参见演示 4

演示 1 -- jQuery

$('button').on('click', fav);

function fav(e) {
$(this).find('.fa').toggleClass('fa-star-o fa-star');
}
:root {
font: 400 16px/1.5 Verdana;
}

button {
display: inline-block;
font: inherit;
padding: 0px 5px;
cursor: pointer;
}

button::after {
content: ' Favorite'
}
<link href='https://cdn.jsdelivr.net/fontawesome/4.7.0/css/font-awesome.min.css' rel='stylesheet'>

<button>
<i class="fa fa-star-o"></i>
</button>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

演示 2 -- 纯 JavaScript

document.querySelector('button').addEventListener('click', fav);

function fav(e) {
const tgt = e.target.firstElementChild;
tgt.classList.toggle('fa-star');
tgt.classList.toggle('fa-star-o');
}
:root {
font: 400 16px/1.5 Verdana;
}

button {
display: inline-block;
font: inherit;
padding: 0px 5px;
cursor: pointer;
}

button::after {
content: ' Favorite'
}
<link href='https://cdn.jsdelivr.net/fontawesome/4.7.0/css/font-awesome.min.css' rel='stylesheet'>

<button>
<i class="fa fa-star-o"></i>
</button>

演示 3 -- 纯 CSS

:root {
font: 400 16px/1.5 Verdana;
}

#fav {
display: none
}

#fav+label {
display: inline-block;
border: 2px outset grey;
padding: 0px 5px;
cursor: pointer;
-webkit-appearance: button;
-moz-appearance: button;
appearance: button;
}

#fav+label::after {
content: ' Favorite'
}

#fav+label>.fa-star-o {
display: inline-block
}

#fav+label>.fa-star {
display: none;
}

#fav:checked+label>.fa-star-o {
display: none;
}

#fav:checked+label>.fa-star {
display: inline-block
}
<link href='https://cdn.jsdelivr.net/fontawesome/4.7.0/css/font-awesome.min.css' rel='stylesheet'>

<input id='fav' type='checkbox'>
<label for='fav'>
<i class="fa fa-star-o"></i>
<i class="fa fa-star"></i>
</label>

Demo 4 -- Font Awesome 5

jQuery/JavaScript/CSS

/* #1 jQuery */
$('button.jq').on('click', jQFav);
function jQFav(e) {
$(this).find('.fa-star').toggleClass('fas far');
}

/* #2 JavaScript */
document.querySelector('button.js').addEventListener('click', JSFav);
function JSFav(e) {
const tgt = e.target.firstElementChild;
tgt.classList.toggle('far');
tgt.classList.toggle('fas');
}
/* #1 JS / #2 jQ */
:root {
font: 400 16px/1.5 Verdana;
}

button {
display: inline-block;
font: inherit;
padding: 0px 5px;
cursor: pointer;
}

button::after {
content: ' Favorite'
}

/* #3 CSS */

#fav {
display: none
}

#fav+label {
display:inline-block;
border: 2px outset grey;
padding: 0px 5px;
cursor: pointer;
-webkit-appearance: button;
-moz-appearance: button;
appearance: button;
}

#fav+label::after {
content: ' Favorite'
}

#fav+label>.far {
display: inline-block;
}

#fav+label>.fas {
display: none;
}

#fav:checked+label>.far {
display: none;
}

#fav:checked+label>.fas {
display: inline-block
}
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.2/css/all.css" crossorigin="anonymous">

<ol>
<li><fieldset>
<legend>jQuery</legend>

<button class='jq'>
<i class='fa-star far'></i>
</button>

</fieldset></li>

<li><fieldset>
<legend>Plain JavaScript</legend>

<button class='js'>
<i class='fa-star far'></i>
</button>

</fieldset></li>

<li><fieldset>
<legend>Pure CSS</legend>

<input id='fav' type='checkbox'>
<label for='fav'>
<i class="fa-star far"></i>
<i class="fa-star fas"></i>
</label>

</fieldset></li>
</ol>

<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

关于javascript - 单击按钮切换 Font Awesome 类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45245301/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com