0

アコーディオンとタブを持つ JSP があります。

アコーディオンで選択されたオプションを起動すると、新しいタブが作成され、起動されます。これにより、IFRAME もタブに読み込まれます。これはうまくいきます。常に表示される静的タブが 1 つあります。jquery cookie js スクリプトが配置されています。jquery ui Web サイトで見たことがありますが、Cookie コードは静的タブで機能します。しかし、新しく作成されたタブで機能するには、これが必要です。

オプションで新しいタブを作成して起動すると、ページを更新すると削除されます。ユーザーがそのタブを閉じない限り、これを保持したいと思います。

助けてください!:)

これがすべてを行う私のJSコードです。

$(function() {

    // Tabs
    $('#tabs').tabs();

    $( "#accordion" )
    .accordion({
        collapsible: true,
        header: "> div > h3"
    })
    .sortable({
        axis: "y",
        handle: "h3",
        stop: function( event, ui ) {
            // IE doesn't register the blur when sorting
            // so trigger focusout handlers to remove .ui-state-focus
            ui.item.children( "h3" ).triggerHandler( "focusout" );
        }
    });     

    // actual addTab function: adds new tab using the title input from the form above
    function addTab(href, page, id, p_id, ul_value) {

        var tab_title = "title: <b>" + ul_value + "</b> | " + p_id;
        var tab_title = tab_title || "Tab " + tab_counter;
        $tabs.tabs( "add", "#tabs-" + tab_counter, tab_title );
        tab_counter++;
        $('#'+id).html(page);
    }

    // Add a new iframe tab
    $('a.treeLink').click(function(e) { 
        e.preventDefault(); 
        var href = $(this).attr('href'); 
        var page = '<iframe src="'+href+'" width="100%" height="100%"></iframe>'; 
        var id = $(this).closest("div").attr("id"); 
        var ui_id = $(this).closest("ul").attr("id"); 
        var li_id = $(this).closest("li").attr("id");
        var ul_value = $(this).closest("ul").attr("value");
        addTab(href, page, ui_id, li_id, ul_value);  
    });     

    var $tab_title_input = $( "#tab_title"),
    $tab_content_input = $( "#tab_content" );
    tab_counter = 2;
    href = "http://localhost:8080/processRequest";

    // tabs init with a custom tab template and an "add" callback filling in the content
    var $tabs = $( "#tabs").tabs({
        cookie: {
            // store cookie for a day, without, it would be a session cookie
            expires: 1
        },
        tabTemplate: "<li><a href='#{href}'>#{label}</a> <span class='ui-icon ui-icon-close'>Remove Tab</span></li>",
        add: function( event, ui ) {
            var tab_content = "Content" || "Tab " + tab_counter + " content.";
            href = href;
            $tabs.tabs('select', '#' + ui.panel.id);
            $( ui.panel ).append( '<iframe frameborder="0" style="border:0px" src="'+href+'" width="100%" height="100%"></iframe>');
        }
    });

    // close icon: removing the tab on click
    // note: closable tabs gonna be an option in the future - see http://dev.jqueryui.com/ticket/3924
    $( "#tabs span.ui-icon-close" ).live( "click", function() {
        var index = $( "li", $tabs ).index( $( this ).parent() );
        if(index != 0){
            $tabs.tabs( "remove", index );
        }
    });
});
4

1 に答える 1

0

私はこれを解決しました。

これを行うために次のことを実行しました。上記のコードの間違った場所にCookieを設定していました。

必要な他の機能も追加しました。

それは次のようにする必要がありました:

    // Tabs
    $('#tabs').tabs({
        cookie: {
            // store cookie for a day, without, it would be a session cookie
            expires: 1
        },
        collapsible: true
    }).find( ".ui-tabs-nav" ).sortable({ axis: "x" });
于 2012-07-27T12:11:23.567 に答える