我需要为我的项目创建手风琴菜单。大部分时间都完成了,但我有一个问题,打开-关闭按钮。当我点击下一个选项卡时,我需要按钮来改变状态。但它们并没有改变。我做错了什么?
$('.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>
$('.answers__tabTitle').not(this).removeClass('active');
这个修复部分解决了问题,但有时按下按钮时,他们的随机顺序切换。我怎样才能解决这个问题?截图链接
发布于 2018-06-14 07:30:01
终于找到了解决办法!将此代码添加到脚本的末尾:
$('.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');
});.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;
}<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>
发布于 2018-06-12 22:54:43
只需将最后一行替换为:
$('.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');
});.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>
发布于 2018-06-12 22:55:04
你差一点就明白了。看我下面的片段。这只是改变最后一行的问题:
$('.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');
});.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>
https://stackoverflow.com/questions/50826555
复制相似问题