[英]Remove the Active class from relevant sections
我正在嘗試編寫一個代碼,它只會從當前部分中刪除活動的 class,而不是從其他部分中刪除。 但是我的代碼也從其他部分刪除了活動的 class 。 我在這里做錯了什么?
$( document ).ready(function() { $(".nav li button").click(function(){ $(".nav li button").removeClass("active"); $(this).addClass("active"); }); });
.nav{ margin:0 0 15px; padding:0; list-style:none; }.nav li{ display:inline-block; }.nav li button.active{ background:green; color:#fff; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div class="list-container"> <ul class="nav"> <li><button>Button 1</button></li> <li><button>Button 2</button></li> <li><button>Button 3</button></li> </ul> <ul class="nav"> <li><button>Button 1</button></li> <li><button>Button 2</button></li> <li><button>Button 3</button></li> </ul> </div>
您可以使用.closest()查找ul
引用當前部分,然后使用.find()查找其中的所有li button
並從中刪除active
class :
$( document ).ready(function() { $(".nav li button").click(function(){ $(this).closest('ul').find('li button').removeClass("active"); $(this).addClass("active"); }); });
.nav{ margin:0 0 15px; padding:0; list-style:none; }.nav li{ display:inline-block; }.nav li button.active{ background:green; color:#fff; }
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div class="list-container"> <ul class="nav"> <li><button>Button 1</button></li> <li><button>Button 2</button></li> <li><button>Button 3</button></li> </ul> <ul class="nav"> <li><button>Button 1</button></li> <li><button>Button 2</button></li> <li><button>Button 3</button></li> </ul> </div>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.