Cod*_*dic 5 html javascript jquery jquery-steps
我正在使用 jquery-steps 创建一个“交互式”两步/三步表单。
我想要实现的一件事是在步骤 2(通常是最后一步)之后显示/隐藏附加步骤,这将是基于复选框值的新的最后一步。如果选中,则应显示第 3 步,否则表单将在第 2 步后提交。但是,我不知道从哪里开始!
这就是我到目前为止的 javascript 部分。
$("#wizard").steps({
headerTag: "h1",
bodyTag: "fieldset",
//transitionEffect: "slideLeft",
onStepChanging: function(event, currentIndex, newIndex)
{
//only apply to first step
if (currentIndex === 0 && ($('#opt1').attr('checked')))
{
$("#wizard").steps("insert", 1, {
title: "Step Title",
content: "<p>Step Body</p>"
});
}
return true;
},
onFinished: function (event, currentIndex)
{
var form = $(this);
form.submit();
},
});Run Code Online (Sandbox Code Playgroud)
完整的表格可以在JSFiddle上找到
希望这个更新的脚本对您有所帮助。</form>将以下代码粘贴到您提供的 JSFiddle 中的基于标记的后面。
<script>
var currentStep = 0; //store current step number
$("#wizard").steps({
headerTag: "h1",
bodyTag: "fieldset",
//transitionEffect: "slideLeft",
onStepChanging: function(event, currentIndex, newIndex)
{
if (newIndex < currentIndex) return true; //Previous button click - allow
else if (currentIndex === 1 && ($('#opt1').is(':checked'))) return true; //If in second step and checkbox checked then proceed to Step 3
else if (currentIndex === 1 && (!$('#opt1').is(':checked'))) return false; //If in second step and checkbox checked then stop at Step 2
return true;
},
onStepChanged: function (event, currentIndex, newIndex) {
currentStep = currentIndex; //Set current step number in currentStep variable
if (currentIndex === 1 && (!$('#opt1').is(':checked'))) //If in second step and checkbox not checked then display Finish button and hide Next button
{
$('a[href="#finish"]').parent().attr("style", "display: block;")
$('a[href="#next"]').parent().attr("style", "display: none;");
}
},
onFinished: function (event, currentIndex)
{
var form = $(this);
form.submit();
},
});
$("#wizard-t-2").hide(); //Hide Step 3 by default
//Event handler for checkbox 1
function ShowHideDiv1(opt1) {
var opt1more = document.getElementById("opt1more");
opt1more.style.display = opt1.checked ? "block" : "none";
if (opt1.checked)
{
$("#wizard-t-2").show();
if (currentStep == 1) //If in second step and checkbox checked then display Next button and hide Finish button
{
$('a[href="#finish"]').parent().attr("style", "display: none;")
$('a[href="#next"]').parent().attr("style", "display: block;");
}
}
else
{
$("#wizard-t-2").hide();
if (currentStep == 1) //If in second step and checkbox not checked then display Finish button and hide Next button
{
$('a[href="#finish"]').parent().attr("style", "display: block;")
$('a[href="#next"]').parent().attr("style", "display: none;");
}
}
}
function ShowHideDiv2(opt2) {
var opt2more = document.getElementById("opt2more");
opt2more.style.display = opt2.checked ? "block" : "none";
}
function showVal(newVal){
document.getElementById("valBox").innerHTML=newVal;
}
</script>
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10434 次 |
| 最近记录: |