尝试使用 a[href="]
选择器 :
$( #tabUL a[href="#tabProducts"] ).trigger( click );
I put together a jsfiddle demo to show it in action, and how to optionally hide the other tabs since often when I m programmatically forcing tabs its to require missing mandatory information be entered on the initial tab before unlocking the other tabs...
Edit
Here is the contents of the jsfiddle:
HTML HTML
<div id="tabs">
<ul>
<li><a href="#tab0">Address</a></li>
<li><a href="#tab1">Shipping</a></li>
<li><a href="#tab2">Parts</a></li>
<li><a href="#tab3">Datasheets</a></li>
</ul>
<div id="tab0">
<h1>This is the first tab (0)</h1>
</div>
<div id="tab1">
<h1>This is the second tab (1)</h1>
</div>
<div id="tab2">
<h1>This is the third tab (2)</h1>
</div>
<div id="tab3">
<h1>This is the fourth tab (3)</h1>
</div>
</div>
<br/>
Select the
<select id="tabSelect">
<option value="0">1st</option>
<option value="1">2nd</option>
<option value="2">3rd</option>
<option value="3">4th</option>
</select>Tab and
<input type="checkbox" id="tabHide" checked="checked" /> Lock the Others
jj 查询
$(document).ready(function () {
$( #tabs ).tabs();
$( #tabSelect ).change(function () {
//pass empty array to unlock any locked tabs
$( #tabs ).tabs({disabled: []}).find( a[href="#tab + $(this).val() + "] ).trigger( click );
if ($( #tabHide ).prop( checked )) {
//hide will be an array like [0,2,3]
var hide = Array();
$( #tabs li ).not( .ui-tabs-active ).each(function () {
hide.push($(this).index());
});
$( #tabs ).tabs({disabled: hide});
}
});
});