Кликабельные изображения на переключателях с помощью jQuery
Я пытаюсь добавить изображения для своих вариантов ответов и сделать их кликабельными вместо выбора в вопроснике, но я действительно застрял.
Я не знаю, нужно ли создавать CSS-классы для кнопок, а затем скрывать их. Но в любом случае, возможно, моя голова полна вещей и не может найти быстрое решение.
Кто-нибудь может мне с этим помочь?
Я был бы очень признателен.
Вот немного моего кода.
Спасибо за поддержку, надеюсь, что у вас есть замечательный год!
(function() {
var questions = [{
question: "¿En qué estado tienes tu idea de negocio?",
choices: ["Idea", "Boceto", "Maduración"],
}, {
question: "Almacenamiento de datos",
choices: ["Internet","App","No lo sé"],
}, {
question: "Calidad de tu App",
choices: ["Alta", "Media", "Baja", "No lo sé"],
}, {
question: "¿Para qué dispositivo quieres desarrollarlo?",
choices: ["Android", "iOS", "Android/iOS"],
}, {
question: "Interfaz de tu App",
choices: ["Sencilla", "Llamativa", "Animada"],
}, {
question: "Beneficio extra de tu App",
choices: ["Publicidad", "App de pago", "Compras en la App", "No lo sé"],
}, {
question: "Sistema de ingreso a tu App",
choices: ["Redes Sociales", "E-mail", "Ninguna", "No lo sé"],
}, {
question: "Intregraciones",
choices: ["Sí", "No", "No lo sé"],
}, {
question: "Configuración perfil de usuario",
choices: ["Sí", "No", "No lo sé"],
}, {
question: "Panel de administración",
choices: ["Sí", "No", "No lo sé"],
}, {
question: "¿Quieres que tu app genere reportes?",
choices: ["Sí", "No", "No lo sé"],
}, {
question: "¿Quieres hacerla multilenguaje?",
choices: ["1 idioma", "2 idiomas", "Multilenguajes"],
}];
var questionCounter = 0; //Tracks question number
var selections = []; //Array containing user choices
var quiz = $('#quiz'); //Quiz div object
// Display initial question
displayNext();
// Click handler for the 'next' button
$('#next').on('click', function (e) {
e.preventDefault();
// Suspend click listener during fade animation
if(quiz.is(':animated')) {
return false;
}
choose();
// If no user selection, progress is stopped
if (isNaN(selections[questionCounter])) {
alert('Por favor selecciona una opción');
} else {
questionCounter++;
displayNext();
}
});
// Click handler for the 'prev' button
$('#prev').on('click', function (e) {
e.preventDefault();
if(quiz.is(':animated')) {
return false;
}
choose();
questionCounter--;
displayNext();
});
// Click handler for the 'Start Over' button
$('#start').on('click', function (e) {
e.preventDefault();
if(quiz.is(':animated')) {
return false;
}
questionCounter = 0;
selections = [];
displayNext();
$('#start').hide();
});
// Animates buttons on hover
$('.button').on('mouseenter', function () {
$(this).addClass('active');
});
$('.button').on('mouseleave', function () {
$(this).removeClass('active');
});
// Creates and returns the div that contains the questions and
// the answer selections
function createQuestionElement(index) {
var qElement = $('<div>', {
id: 'question'
});
var image=$('<div>',{'id':'imagelogo'});
var header = $('<h5>' + (index + 1) + '/12</h5>').addClass('contador');
qElement.append(header).append(image);
var question = $('<p>').append(questions[index].question);
qElement.append(question);
var radioButtons = createRadios(index);
qElement.append(radioButtons);
return qElement;
}
// Creates a list of the answer choices as radio inputs
function createRadios(index) {
var radioList = $('<ul>');
var item;
var input = '';
for (var i = 0; i < questions[index].choices.length; i++) {
item = $('<li>');
input = '<input type="radio" name="answer" value=' + i + ' />';
input += questions[index].choices[i];
item.append(input);
radioList.append(item);
}
return radioList;
}
// Reads the user selection and pushes the value to an array
function choose() {
selections[questionCounter] = +$('input[name="answer"]:checked').val();
}
// Displays next requested element
function displayNext() {
quiz.fadeOut(function() {
$('#question').remove();
if(questionCounter < questions.length){
var nextQuestion = createQuestionElement(questionCounter);
quiz.append(nextQuestion).fadeIn();
if (!(isNaN(selections[questionCounter]))) {
$('input[value='+selections[questionCounter]+']').prop('checked', true);
}
// Controls display of 'prev' button
if(questionCounter === 1){
$('#prev').show();
} else if(questionCounter === 0){
$('#prev').hide();
$('#next').show();
}
}else {
var scoreElem = displayScore();
quiz.append(scoreElem).fadeIn();
$('#next').hide();
$('#prev').hide();
$('#start').show();
}
});
}
// Computes score and returns a paragraph element to be displayed
function displayScore() {
var score = $('<p>',{id: 'question'});
var numCorrect = 0;
for (var i = 0; i < selections.length; i++) {
if (selections[i] === questions[i].correctAnswer) {
numCorrect++;
}
}
score.append('<strong>¡A punto de aterrizar!</strong>' + '<br>' + 'En unos minutos nuestro equipo especializado' +
' se contactará contigo');
return score;
}
})();
Вот мой HTML-код.
<!-- Page Content -->
<section class="content-section-a spacing idea">
<div class="col-xs-12 col-sm-6 col-md-8 col-lg-12">
<div class="container">
<center>
<h3 class="color" id="left"><strong> Hola (Nombre y Apellido) </strong> <br> <span id="left"> Calculemos tu App </span> </h3>
</center>
<br>
</div>
<div class="clearfix"></div>
<div class="col-xs-12 col-sm-6 col-md-8 col-lg-12">
<div class="container">
<div id='quiz'></div>
<div class='button' id='next'><a href='#'>Siguiente</a></div>
<div class='button' id='prev'><a href='#'>Anterior</a></div>
<div class='button' id='start'> <a href='#'>Comenzar nuevamente</a></div>
<!-- <button class='' id='next'> Siguiente </a></button>
<button class='' id='prev'> Anterior </a></button>
<button class='' id='start'> Comenzar nuevamente </a></button> -->
</div>
</div>
</div>
</section>
<!--End of Page Content-->