<script>
$(function() {
$( "#tabs" ).tabs({
ajaxOptions: {
error: function( xhr, status, index, anchor ) {
$( anchor.hash ).html("Couldn't load this tab.");
}
}
});
});
</script>
<div class="demo">
<div id="tabs">
<ul>
<li><a href="#tabs-1">Preloaded</a></li>
<li><a href="ajax/content1.html">Tab 1</a></li>
<li><a href="ajax/content2.html">Tab 2</a></li>
</ul>
<div id="tabs-1">
<p>Proin elit arcu, rutrum commodo.</p>
</div>
如果在这种情况下发送带有帖子数据的 ajax请求(可能通过ajaxOptions)。
我不知道如何修改标签网址来发送帖子数据,例如:
<li><a href="ajax/content1.html(country:1,city:35)">Tab 1</a></li>
<li><a href="ajax/content2.html(code:'aa')">Tab 1</a></li>
谢谢!
EDITED :
在jQuery中它是:
$.load("some_url",{country: countryValue});
所以我有帖子标题(国家)和帖子值(countryValue)。 如何对每个标签做同样的事情?
答案 0 :(得分:5)
要使AJAX方法POST,您可以向type
对象添加ajaxOptions
。要收集帖子的数据,您可以利用jQuery.data()
然后隐藏锚点中的POST参数。
<div id="tabs">
<ul>
<li><a href="#tabs-1">Preloaded</a></li>
<li><a href="ajax/content1.html">Tab 1</a></li>
<li><a href="ajax/content2.html" data-country="1" data-city="35">Tab 2</a></li>
<li><a href="ajax/content3-slow.php">Tab 3 (slow)</a></li>
<li><a href="ajax/content4-broken.php">Tab 4 (broken)</a></li>
</ul>
<div id="tabs-1">
<p>Proin elit arcu, rutrum commodo.</p>
</div>
JavaScript:
var postData = {};
$("#tabs").tabs({
select: function(event, ui) {
postData = {
country: parseInt($(ui.tab).data('country')),
city: parseInt($(ui.tab).data('city'));
};
},
ajaxOptions: {
type: 'POST',
data: postData,
error: function(xhr, status, index, anchor) {
$(anchor.hash).html("Couldn't load this tab. We'll try to fix this as soon as possible. " + "If this wouldn't be a demo.");
}
}
});
试一试:JSFiddle
如果您的参数对每个链接都有所改变,那么您必须想出一种方法来了解您正在寻找的参数。您可以使用select()
获取ui.index
事件中标签的索引,并使用switch
为每个案例获取不同的参数。不可否认,这个解决方案不是很漂亮,但它可以工作。