2011-04-12 61 views
1

所以我有一些导航由浮动在传统锚点旁边的表单复选框组成。如果没有选中相应的复选框,我想添加一个类(基本上会调整样式以调暗锚标记)。有系统地做这件事的最好方法是什么?ToggleClass基于复选框状态

<div id="navPod"> 
    <form method="post" action="#" id="contentFilterForm" name="contentFilterForm"> 
     <input type="hidden" name="q" value="<?php echo $q;?>" /> 
     <input class="checkbox" type="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'projects'){ echo "checked=\"checked\"";} if($proj){ echo "checked=\"checked\"";} ?> name="pr" value="1" id="filterProjects" /> 
     <input class="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'playground'){ echo "checked=\"checked\"";} if($playground){ echo "checked=\"checked\"";} ?> type="checkbox" name="pl" value="1" id="filterPlayground" /> 
     <input class="checkbox" type="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'about'){ echo "checked=\"checked\"";} if($culture){ echo "checked=\"checked\"";} ?> name="cu" value="1" id="filterCulture" /> 
     <input class="checkbox" type="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'leadership'){ echo "checked=\"checked\"";} if($leadership){ echo "checked=\"checked\"";} ?> name="le" value="1" id="filterLeadership" /> 
     <input class="checkbox" type="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'careers'){ echo "checked=\"checked\"";} if($jobs){ echo "checked=\"checked\"";} ?> name="ca" value="1" id="filterCareers" /> 

     <input class="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'blog'){ echo "checked=\"checked\"";} if($blog){ echo "checked=\"checked\"";} ?> type="checkbox" name="bl" value="1" id="filterBlog" /> 
     <input class="checkbox" <?php if($pagetype == 'home'){ echo "checked=\"checked\"";} if($pagetype == 'delicious'){ echo "checked=\"checked\"";} if($links){ echo "checked=\"checked\"";} ?> type="checkbox" name="li" value="1" id="filterDelicious" /> 

     <input id="refreshSubmit" type="button" value="" onclick="createURLS()"/> 
    </form> 

    <div class="subnav"> 
     <a id="projectsLink" title="Projects" href="/projects/" <?php if($pagetype == 'projects'){ echo "class=\"currentPage\""; } ?> >Projects</a><br /> 
     <a id="playgroundLink" title="Playground" href="/playground/" <?php if($pagetype == 'playground'){ echo "class=\"currentPage\""; } ?> >Playground</a><br />    
     <a id="aboutLink" title="About Centerline Digital" href="/about/" <?php if($pagetype == 'about'){ echo "class=\"currentPage\""; } ?> >About Us</a><br /> 
     <a id="leadershipLink" title="Leadership" href="/leadership/" <?php if($pagetype == 'leadership'){ echo "class=\"currentPage\""; } ?> >Leadership</a><br /> 
     <a id="careersLink" title="Careers" href="/careers/" <?php if($pagetype == 'careers'){ echo "class=\"currentPage\""; } ?> >Careers</a><br /> 
     <a id="blogLink" title="Blog" href="/blog/" <?php if($pagetype == 'blog'){ echo "class=\"currentPage\""; } ?> >Blog</a><br /> 
     <a id="thoughtsLink" title="Thoughts and Links" href="/thoughts/" <?php if($pagetype == 'delicious'){ echo "class=\"currentPage\""; } ?> >Thoughts and Links</a><br /> 

     <a target="_blank" title="Subscribe to Custom Feed" id="feedLink" href="/dyn/">Subscribe to Custom Feed</a> 
    </div> 
</div> 

回答

1
基于HTML

我会尝试这个

$('input:checkbox').each(function(){ 
var anchor_id = $(this).attr('id').replace('filter','').toLowerCase();; 
    $('#'+anchor_id+'Link').toggleClass('someclass', $(this).attr('checked')); 
}); 
$('input:checkbox').change(function(){ 
    var anchor_id = $(this).attr('id').replace('filter','').toLowerCase();; 
    $('#'+anchor_id+'Link').toggleClass('someclass', $(this).attr('checked')); 
}) 

working demo

+0

这个替换整个的if/else块:'$( '#' + anchor_id).toggleClass ('someclass',$(this).attr('checked'));'让我们在这里保持干爽,人。 – 2011-04-12 16:22:23

+0

@ adam-terlson良好的呼叫感谢 – mcgrailm 2011-04-12 16:51:13

+0

嗯,一个小猴子扳手扔在这里。另一块jQuery拦截检查的attrib(ez-checked)。我有'$''checkbox')。change(function(){ var anchor_id = $(this).attr('id')。replace('filter',''); $(' #'+ anchor_id).toggleClass('filtered',$(this).attr('checked')); })'但toggleClass永远不会触发,因为它没有看到任何被视为真的检查。 – Keefer 2011-04-12 17:49:35

0
$(function(){ 
    $("a[id$='Link']").each(function(){ 
     var checkboxID = this.id.replace("Link", ""); 
     checkboxID = "filter" + checkboxID[0].toUpperCase() + checkboxID.substr(1); 

     $(this).addClass($("#" + checkboxID).is(":checked") ? "dim" : ""); 
    }) 
})