kex*_*eam 1 html jquery addclass hover html-lists
问题: 我想在一个li元素的子元素中添加一个类.
HTML代码:
<li class="active">
<a href="index.html" title="Homepage">Homepage<i class="icon-home"></i></a>
</li>
Run Code Online (Sandbox Code Playgroud)
jQuery代码:
<script type="text/javascript">
$(document).ready(function()
{
$('li[ class="active" ]').hover(
function(){ $(this).addClass('icon-white') },
function(){ $(this).removeClass('icon-white') }
)
});
</script>
Run Code Online (Sandbox Code Playgroud)
期望的结果:
<li class="active">
<a href="index.html" title="Homepage">Homepage<i class="icon-home icon-white"></i></a>
</li>
Run Code Online (Sandbox Code Playgroud)
将类添加到特定元素的代码:
<script type="text/javascript">
$(document).ready(function()
{
if ($('#main-nav > li').hasClass('active') == true)
{
$("a > i", this).addClass('icon-white');
}
});
</script>
Run Code Online (Sandbox Code Playgroud)
更新(最终解决方案):
<script type="text/javascript">
$(document).ready(function()
{
$('#main-nav li').hover(function()
{
if ($(this).hasClass('active') != true)
{
$('a', this).find('i').toggleClass('icon-white');
}
});
$("#main-nav li.active > a > i").addClass('icon-white');
});
</script>
Run Code Online (Sandbox Code Playgroud)
提前致谢!
$(document).ready(function() {
$('li.active').hover(
function() {
$('a', this).addClass('icon-white');
}, function() {
$('a', this).removeClass('icon-white');
});
});
Run Code Online (Sandbox Code Playgroud)
也可以写(更好)
$('li.active').hover(
function() {
$('a', this).toggleClass('icon-white');
});
Run Code Online (Sandbox Code Playgroud)
使用jQuery .on()悬停:
$(document).ready(function() {
$('li.active').on('hover',
function() {
$('a', this).toggleClass('icon-white');
});
});
Run Code Online (Sandbox Code Playgroud)
根据评论
i?$('i', this).addClass('icon-white');
Run Code Online (Sandbox Code Playgroud)
同样适用于.removeClass()或.toggleClass().
根据编辑
$(document).ready(function(){
$("li.active > a > i").addClass('icon-white');
});
Run Code Online (Sandbox Code Playgroud)
结合悬停:
$("li.active > a > i").addClass('icon-white');
$('li.active').hover(
function() {
$('a', this).toggleClass('icon-white');
});
Run Code Online (Sandbox Code Playgroud)