В этом решении, прежде всего, вам нужно создать переменную и использовать ее для указания числа .custom_config
активных на вашей странице.
Например, в ситуации инициализации вам придетсяАктивируйте первый, когда вы нажимаете первый раз на кнопку «Далее», второй и т. д.
Итак, создайте эту переменную и установите ее равной 1 (ваше начальное значение), а также завершите исходную ситуацию (т. е. first .custom_config
active и .back
& #checkoutbtn
hidden):
$(".back, #checkoutbtn").hide();
$(".custom_config:nth-of-type(1)").addClass("open");
var i = 1;
После этого вам необходимо создать функцию, которая проверяет, что должно произойти, когда число вашей переменной изменит свое значение. Все элементы управления находятся в этой функции (я прокомментировал каждую строку)
function control(){
if(i <= 1){
// if i is equals to or smaller than 1...
i = 1; // ...put i always equals to 1...
$(".back").hide() // ...hide .back button
$(".next").show(); // ...show .next button
} else if (i >= $(".custom_config").length){
// if i is equals to or greater than the .custom_config length...
i = $(".custom_config").length; // ...put i always equals to your .custom_config length
$("#checkoutbtn").show(); // ...then show checkoutbtn
$(".next").hide(); // ...hide next button
} else {
// in all other cases...
$("#checkoutbtn").hide(); // hide checkout button
$(".back, next").show(); // show back & next button
}
$(".custom_config").removeClass("open"); // after that always remove class open to all your .custom_config div...
$(".custom_config:nth-of-type("+i+")").addClass("open"); //and put it to correct .custom_config that you need to see
}
Теперь ваши кнопки .next
и .back
должны только добавлять или удалять единицы из вашей переменной:
$(".next, .back").on("click", function(e){
if($(this).hasClass("next")) i ++;
else i --;
control();
});
РЕДАКТИРОВАТЬ 1 Для проблемы, о которой вы говорите в своем комментарии, попробуйте добавить e.preventDefault();
к функции:
$(".next, .back").on("click", function(e){
e.preventDefault(); //add this line
if($(this).hasClass("next")) i ++;
else i --;
control();
});
Также добавьте $(".next").show();
к функции control
чтобы предотвратить небольшую ошибку, которую я заметил. Я переписал фрагмент с этими изменениями, попробуйте:
$(".back, #checkoutbtn").hide();
$(".custom_config:nth-of-type(1)").addClass("open");
var i = 1;
$(".next, .back").on("click", function(e){
e.preventDefault();
if($(this).hasClass("next")) i ++;
else i --;
control();
});
function control(){
if(i <= 1){
i = 1;
$(".back").hide()
$(".next").show();
} else if (i >= $(".custom_config").length){
i = $(".custom_config").length;
$(".next").hide();
$("#checkoutbtn").show();
} else {
$("#checkoutbtn").hide();
$(".back, .next").show();
}
$(".custom_config").removeClass("open");
$(".custom_config:nth-of-type("+i+")").addClass("open");
}
/* you can remove these CSS */
.custom_config:nth-of-type(1){
background-color:red;
}
.custom_config:nth-of-type(2){
background-color:yellow;
}
.custom_config:nth-of-type(3){
background-color:green;
}
/* you can remove these CSS */
.custom_config{
display:none;
}
.open{
display:block;
}
<script src="https://code.jquery.com/jquery-3.4.1.min.js" integrity="sha256-CSXorXvZcTkaix6Yvo6HppcZGetbYMGWSFlBw8HfCJo=" crossorigin="anonymous"></script>
<form method="post" action="/cart/add" id="12345" accept-charset="UTF-8" class="shopify-product-form" enctype="multipart/form-data">
<input type="hidden" name="form_type" value="product">
<input type="hidden" name="utf8" value="✓">
<section class="custom_config">
<ul>
<li><input class="choice" id="keep" type="radio" name="properties[Background]" value="keep" required="">
<label for="keep">Keep</label></li>
<li><input class="choice" id="remove" type="radio" name="properties[Background]" value="remove" required="">
<label for="remove">Remove</label></li>
</ul>
</section>
<section class="custom_config"> Content 2 </section>
<section class="custom_config"> Content 3 </section>
<button class="back">Back</button>
<button class="next">Next</button>
<button id="checkoutbtn" type="submit" class="btn btn-lg js-add-to-cart-product-page" data-product-handle="custom" data-variant-id="20262476120160" title="Add to Cart"><span>Add to Cart</span></button>
</form>