我需要为我的项目创建一个手风琴菜单。大部分已完成,但我有一个开关按钮的问题。单击下一个选项卡时,我需要按钮来更改状态。但他们并没有改变。我做错了什么?
$('.answers__tabTitle').next().hide();
$('.answers__tabTitle').click(function(){
$(this).next().slideToggle();
$('.answers__tabTitle').not(this).next().stop(true,true).slideUp();
$(this).addClass('active');
$('.active .open-close').toggleClass('on');
$(this).removeClass('active');
});

.answers__tabText {
font-family: "MuseoSansCyrl_300";
font-size: 21px;
text-align: left;
padding: 20px;
}
.answers__tabTitle .open-close {
width: 30px;
height: 30px;
float: right;
transform: rotate(45deg);
transition: all .3s ease;
opacity: .8;
}
.answers__tabTitle .on {
transform: rotate(0deg);
opacity: .4;
}

<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="answers__tabsWrap">
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка входной двери зависит от многих факторов. Минимальная цена, которая может быть это 1 600 рублей. Точную цену установки, под Ваш проём может назвать технический специалист на замере.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько времени идёт изготовление двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Процесс изготовления стандартных дверей занимает 7-10 дней, а нестандартных 10-14 дней в зависимости от сложности конструкции двери. Возможно срочное изготовление за 3 дня. Доплата 1 000 рублей.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит замер проёма входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Замер проёма входной двери по Ульяновской области бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит демонтаж старой двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Демонтаж старой двери бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Когда будет установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка стандартных дверей, которые есть на складе может быть произведена на следующий день после заключения договора. Если Вам нужна дверь нестандартного размера, то надо будет ожидать время изготовления, потом Вам позвонит менеджер и Вы с ним договоритесь на любой удобный для вас день.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит доставка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Доставка входной двери в пределах города Ульяновска стоит 500 рублей, а за пределами города 1 километр = 17 рублей. Также возможен самовывоз входной двери.</p>
<hr>
</div>
</div>
&#13;
$(&#39; .answers__tabTitle&#39)。不(本).removeClass(&#39;有源&#39);
此修复程序部分解决了问题,但有时按钮在按随机顺序切换时保持按下状态。我怎样才能解决这个问题? screenshot link
答案 0 :(得分:0)
您只需要将最后一行替换为:
$('.answers__tabTitle').not(this).removeClass('active');
这是一个有效的例子:
$('.answers__tabTitle').next().hide();
$('.answers__tabTitle').click(function(){
$(this).next().slideToggle();
$('.answers__tabTitle').not(this).next().stop(true,true).slideUp();
$(this).addClass('active');
$('.active .open-close').toggleClass('on');
$('.answers__tabTitle').not(this).removeClass('active');
});
&#13;
.answers__tabText {
font-family: "MuseoSansCyrl_300";
font-size: 21px;
text-align: left;
padding: 20px;
}
.answers__tabTitle .open-close {
width: 30px;
height: 30px;
float: right;
transform: rotate(45deg);
transition: all .3s ease;
opacity: .8;
}
.answers__tabTitle .on {
transform: rotate(0deg);
opacity: .4;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="answers__tabsWrap">
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка входной двери зависит от многих факторов. Минимальная цена, которая может быть это 1 600 рублей. Точную цену установки, под Ваш проём может назвать технический специалист на замере.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько времени идёт изготовление двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Процесс изготовления стандартных дверей занимает 7-10 дней, а нестандартных 10-14 дней в зависимости от сложности конструкции двери. Возможно срочное изготовление за 3 дня. Доплата 1 000 рублей.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит замер проёма входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Замер проёма входной двери по Ульяновской области бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит демонтаж старой двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Демонтаж старой двери бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Когда будет установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка стандартных дверей, которые есть на складе может быть произведена на следующий день после заключения договора. Если Вам нужна дверь нестандартного размера, то надо будет ожидать время изготовления, потом Вам позвонит менеджер и Вы с ним договоритесь на любой удобный для вас день.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит доставка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Доставка входной двери в пределах города Ульяновска стоит 500 рублей, а за пределами города 1 километр = 17 рублей. Также возможен самовывоз входной двери.</p>
<hr>
</div>
</div>
&#13;
答案 1 :(得分:0)
你几乎得到了它。请参阅下面的我的代码段。这只是改变最后一行的问题:
$('.answers__tabTitle').not(this).removeClass('active');
$('.answers__tabTitle').next().hide();
$('.answers__tabTitle').click(function() {
$(this).next().slideToggle();
$('.answers__tabTitle').not(this).next().stop(true, true).slideUp();
$(this).addClass('active');
$('.active .open-close').toggleClass('on');
$('.answers__tabTitle').not(this).removeClass('active');
});
&#13;
.answers__tabText {
font-family: "MuseoSansCyrl_300";
font-size: 21px;
text-align: left;
padding: 20px;
}
.answers__tabTitle .open-close {
width: 30px;
height: 30px;
float: right;
transform: rotate(45deg);
transition: all .3s ease;
opacity: .8;
}
.answers__tabTitle .on {
transform: rotate(0deg);
opacity: .4;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="answers__tabsWrap">
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка входной двери зависит от многих факторов. Минимальная цена, которая может быть это 1 600 рублей. Точную цену установки, под Ваш проём может назвать технический специалист на замере.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько времени идёт изготовление двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Процесс изготовления стандартных дверей занимает 7-10 дней, а нестандартных 10-14 дней в зависимости от сложности конструкции двери. Возможно срочное изготовление за 3 дня. Доплата 1 000 рублей.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит замер проёма входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Замер проёма входной двери по Ульяновской области бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит демонтаж старой двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Демонтаж старой двери бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Когда будет установка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка стандартных дверей, которые есть на складе может быть произведена на следующий день после заключения договора. Если Вам нужна дверь нестандартного размера, то надо будет ожидать время изготовления, потом Вам позвонит менеджер и Вы с ним
договоритесь на любой удобный для вас день.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит доставка входной двери?<img class="open-close on" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Доставка входной двери в пределах города Ульяновска стоит 500 рублей, а за пределами города 1 километр = 17 рублей. Также возможен самовывоз входной двери.</p>
<hr>
</div>
</div>
&#13;
答案 2 :(得分:0)
最后,找到了解决方案! 将此代码添加到脚本的末尾:
$('.open-close').not('.active .open-close').removeClass('on');
这有效!感谢所有人(当然还有我))的帮助!
$('.answers__tabTitle').next().hide();
$('.answers__tabTitle').click(function(){
$(this).next().slideToggle();
$('.answers__tabTitle').not(this).next().stop(true,true).slideUp();
$(this).addClass('active');
$('.active .open-close').toggleClass('on');
$('.answers__tabTitle').not(this).removeClass('active');
$('.open-close').not('.active .open-close').removeClass('on');
});
&#13;
.answers__tabText {
font-family: "MuseoSansCyrl_300";
font-size: 21px;
text-align: left;
padding: 20px;
}
.answers__tabTitle .open-close {
width: 30px;
height: 30px;
float: right;
transition: all .3s ease;
opacity: .4;
}
.answers__tabTitle .on {
transform: rotate(45deg);
opacity: .8;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div class="answers__tabsWrap">
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит установка входной двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка входной двери зависит от многих факторов. Минимальная цена, которая может быть это 1 600 рублей. Точную цену установки, под Ваш проём может назвать технический специалист на замере.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько времени идёт изготовление двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Процесс изготовления стандартных дверей занимает 7-10 дней, а нестандартных 10-14 дней в зависимости от сложности конструкции двери. Возможно срочное изготовление за 3 дня. Доплата 1 000 рублей.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит замер проёма входной двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Замер проёма входной двери по Ульяновской области бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит демонтаж старой двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Демонтаж старой двери бесплатный.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Когда будет установка входной двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Установка стандартных дверей, которые есть на складе может быть произведена на следующий день после заключения договора. Если Вам нужна дверь нестандартного размера, то надо будет ожидать время изготовления, потом Вам позвонит менеджер и Вы с ним договоритесь на любой удобный для вас день.</p>
<hr>
</div>
<div class="answers__tab">
<hr>
<p class="answers__tabTitle">Сколько стоит доставка входной двери?<img class="open-close" src="http://i.piccy.info/i9/ee9f224ec07247dfc032542552a70df2/1528841272/408/1250964/open_close.png" alt="open-close"></p>
<p class="answers__tabText">Доставка входной двери в пределах города Ульяновска стоит 500 рублей, а за пределами города 1 километр = 17 рублей. Также возможен самовывоз входной двери.</p>
<hr>
</div>
</div>
&#13;