我一直在撞牆的一天,現在試圖找出一些簡單的標籤操作。我有3個選項卡,每個選項卡都包含不同的表單部分。當用戶在第一個時,我需要禁用第二個和第三個。然後,當填寫第一頁並單擊繼續並且驗證返回true時,我可以啓用第二個選項卡並滑動到該位置。然後,當他們完成第二頁時,點擊繼續,並驗證返回true,我可以啓用第三個選項卡並滑入它。主要的是我需要禁用選項卡,直到他們當前所在的選項卡被驗證。因此,這裏是我的html:HTML/Bootstrap標籤
<ul class="nav nav-tabs" id="myTab">
<li><a href="#options">Options</a></li>
<li><a href="#information">Information</a></li>
<li><a href="#payment">Payment</a></li>
</ul>
<div class="tab-content">
<div class="tab-pane active" id="options">
<form id="frmtype1" action="" name="frmtype1" method="post">
<header>Registration Options</header>
<br/>
<label for="Reg_type1" class="checkbox">
<input type="radio" name="Reg_type" id="Reg_type1" value="1"/>
Registering myself with credit card or bank account
</label>
<br>
<label for="Reg_type2" class="checkbox">
<input type="radio" name="Reg_type" id="Reg_type2" value="2"/>
Registering multiple people using credit card or bank account
</label>
<br>
<label for="Reg_type3" class="checkbox">
<input type="radio" name="Reg_type" id="Reg_type3" value="3"/>
Registering using a purchase order
</label>
<div class="form-actions">
<button class="btn" type="submit">Continue</button><span class="help-inline" style="display:none;">Please choose an option</span>
</div>
</form>
</div>
<div class="tab-pane" id="information">...</div>
<div class="tab-pane" id="payment">...</div>
</div>
然後我的jquery:
var val1 = $('#frmtype1').validate({
$('#myTab a[href="#information"]').tab('disabled'); //i have no idea how to prevent the user from navigating here so I just put disabled. Didn't work obviously
$('#myTab a[href="#payment"]').tab('disabled');
errorPlacement: function(error, element) {}, //this is to prevent the standard error message from showing, rather you use the inline-text
rules: {
'Reg_type': {
required: true
}
}
});
$('#frmtype1').submit(function(e) {
/*This will validate the first page, if the user didn't select an option then it will display
the inline text as an error message*/
if(val1.form()) {
$('.help-inline').hide();
} else {
$('.help-inline').show();
return false;
}
});
$('#myTab a').click(function (e) {
e.preventDefault();
$(this).tab('show');
})
所以首先第一件事情,我如何禁用後續的標籤,直到當前選項卡的形式進行驗證爲真?