jQuery UI选项卡:如何使用发布数据发送ajax请求?

时间:2011-11-28 19:28:14

标签: jquery-ui jquery jquery-ui-tabs

来自jQuery UI tabs

<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)。 如何对每个标签做同样的事情?

1 个答案:

答案 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为每个案例获取不同的参数。不可否认,这个解决方案不是很漂亮,但它可以工作。