Jquery 向导-“重新开始”按钮
我已经创建了我的向导,并且按照我需要的方式工作,但我的问题是如何在结果页面上创建一个“重新开始”按钮,该按钮将清除所有单选按钮并显示起始div 目前我在两个results div中有相同的按钮,但只有第一个有效。帮助选择问题1-答案1,然后选择问题2-答案1或2以了解我所说的内容Jquery 向导-“重新开始”按钮,jquery,wizard,Jquery,Wizard,我已经创建了我的向导,并且按照我需要的方式工作,但我的问题是如何在结果页面上创建一个“重新开始”按钮,该按钮将清除所有单选按钮并显示起始div 目前我在两个results div中有相同的按钮,但只有第一个有效。帮助选择问题1-答案1,然后选择问题2-答案1或2以了解我所说的内容 另外,如果您对如何实现此向导有其他更简单的想法,请告诉我。您可能从评论中看到,您的脚本有点小。这种编程方式在任何方面都不是动态的。它可能在某种程度上起作用,但正如您可能已经经历过的那样,维护它是非常可怕的 对于这样的应
另外,如果您对如何实现此向导有其他更简单的想法,请告诉我。您可能从评论中看到,您的脚本有点小。这种编程方式在任何方面都不是动态的。它可能在某种程度上起作用,但正如您可能已经经历过的那样,维护它是非常可怕的 对于这样的应用程序,您需要制作一个核心插件来处理某种数组,其中包含问题和答案。这似乎是一个有趣的挑战,所以我创建了一个插件,它基于您的示例参数。它叫DawnWizard 我希望您能理解此插件的一般概念,并在您的下一个项目中应用相同的方法:
/*
* DawnWizard v1.0
* Originally made for Dawn's question in StackOverflow
* http://stackoverflow.com/questions/6378814/
*
* Made by Kalle H. Väravas
* http://stackoverflow.com/users/721553/
*
* No direct copyright or licences.
* Use however you want, just give me lots of +1 :)
*/
(function ($) {
$.fn.exists = function () {return $(this).length > 0;}
$.fn.DawnWizard = function (input_setup) {
var default_setup = {
title: 'Demo wizard',
description: 'Welcome text..'
};
setup = jQuery.extend(default_setup, input_setup || {});
var wizard_container = $(this);
var questions_count = 0;
jQuery.each(setup['questions'], function () {
questions_count++;
});
load_startup = function () {
results = [];
wizard_container.empty().append(
$('<h1>').html(setup['wizard']['title']),
content_container = $('<div id="content">').append(
$('<p>').html(setup['wizard']['description']),
$('<button id="start_wizard" />').text('Start the Wizard')
)
);
$('#start_wizard').click(function () {
load_question(current_qid = 1);
});
};
load_results = function () {
content_container.empty().append(results_container = $('<p>'));
jQuery.each(setup['questions'], function (i, question) {
results_container.append($('<div>').text(explain_qid(i) + ' - ' + results[i]));
});
content_container.after($('<button id="start_over">').text('Start over'));
current_qid = 1;
$('#start_over').click(function () {
load_startup(current_qid = 1);
});
};
load_question = function (qid) {
if (qid == 0) {
load_startup();
return;
} else if (qid == questions_count + 1) {
load_results();
return;
}
content_container.empty().append(
$('<p>').append(
$('<b id="question">').html(setup['questions'][qid]['question']),
questions = $('<ul>')
),
$('<button id="previous">').text('Previous'),
$('<button id="next">').text('Next')
);
jQuery.each(setup['questions'][qid]['answers'], function (i, answer) {
questions.append($('<li><input type="radio" name="answer" value="' + answer + '"> ' + answer + '</li>'));
});
$('#previous, #next').click(function () {
var action = $(this).attr('id');
var checked_answer = $('input[name=answer]:checked');
if (action == 'previous') {
load_question(current_qid = current_qid - 1);
} else if (action == 'next') {
if (checked_answer.size() > 0) {
insert_result(current_qid, checked_answer.val());
load_question(current_qid = current_qid + 1);
} else {
add_message('You forgot to check an answer!', 'error');
}
}
});
};
insert_result = function (qid, answer) {
results[qid] = answer;
};
explain_qid = function (qid) {
return setup['questions'][qid]['question'];
};
add_message = function (message, type) {
if (jQuery.inArray(type, ['error', 'success'])) {
return;
}
if (!$('#message').exists()) {
content_container.before(
$('<div id="message" class="' + type + '">')
.text(message)
.fadeIn()
.delay(2000)
.fadeOut('normal', function () {
$(this).remove();
})
);
}
};
load_startup();
};
}) (jQuery);
[-]你的代码让我希望你知道什么is@Raynos:这是一个很好的模式:-非常严肃地说@OP,使用函数和其他东西来避免重复你自己是非常方便的!我对这类编程不是很熟练,这就像一棵问答树。所以答案1可以带你到问题3,但答案2可以带你到问题4,如果这有任何意义的话,它会继续下去。我一直在试图找到一种方法来构建这段代码,这是我唯一能想到的方法。有什么方法可以清理这段代码吗?我是新来的。从六月开始一直在做这个不过做得很好,谢谢你对每件事都发表评论,这样OP就可以学到一些东西,而不仅仅是得到一份讲义。@Wesley,我喜欢回答老问题-没有种族压力^^^^^而且,在做的时候可能会得到一些徽章和新知识。。但是谢谢你的支持:我不确定使用对象数组是否是最理想的方式。。但我测试了所有其他概念,这似乎是最有效的方法。
$('#put_wizard_here').DawnWizard({
wizard: {
title: 'Demo wizard',
description: 'Welcome text..'
},
questions: {
1: {
question: 'Who is hotter?',
answers: [
'Miley', 'Selena', 'Mila'
]
},
2: {
question: 'Who is the smartest?',
answers: [
'Kalle H. Väravas', 'Kalle\'s colleague'
]
},
3: {
question: 'Coolest StackExchange?',
answers: [
'StackOverflow', 'Programmers', 'Gaming'
]
}
}
});