Jquery 自定义选项卡使用 Cookie 持久化

发布于 2025-01-08 07:26:07 字数 4380 浏览 0 评论 0原文

我使用 jquery(和 ASP.NET MVC3 Razor 引擎)进行了简单的选项卡设置。
这是 html:

<ul id="tabul">
    <li id="litab" class="ntabs add"><a href="" id="addtab">+</a></li>
    <li id="hometab" class="ntabs">Home</li>
    <li id="componentstab" class="ntabs">Components</li>
    <li id="documentstab" class="ntabs">Documents</li>
    <li id="userstab" class="ntabs">Users</li>
</ul>
<div id="tabcontent">
    <div id="hometabcontent" class="tabcontainer">
        @{
            Html.RenderPartial("GetTest1Tab");
        }
    </div>
    <div id="componentstabcontent" class="tabcontainer" style="display: none;">
        @{
            Html.RenderPartial("GetTest2Tab");
        }
    </div>
    <div id="documentstabcontent" style="display: none;" class="tabcontainer">
        @{
            Html.RenderPartial("GetTest3Tab");
        }    
    </div>
    <div id="userstabcontent" style="display: none;" class="tabcontainer">
        @{
            Html.RenderPartial("GetTest4Tab");
        }
    </div>
</div>

这是 JQuery:

        $(function () {
            var total_tabs = 0;

            $("#tabcontent .tabcontainer").hide();
            $("#hometabcontent").fadeIn('slow');

            $("#addtab, #litab").click(function () {
                total_tabs++;
                $("#tabcontent .tabcontainer").hide();
                addtab(total_tabs);
                return false;
            });
            $("#hometab").click(function () {
                $("#tabul li").removeClass("ctab");
                $("#hometab").addClass("ctab");
                $("#tabcontent .tabcontainer").hide();
                $("#hometabcontent").show();
                $("#hometabcontent").children().show();
            });

            $("#componentstab").click(function () {
                $("#tabul li").removeClass("ctab");
                $("#componentstab").addClass("ctab");
                $("#tabcontent .tabcontainer").hide();
                $("#componentstabcontent").fadeIn('slow');
            });
            $("#documentstab").click(function () {
                $("#tabul li").removeClass("ctab");
                $("#documentstab").addClass("ctab");
                $("#tabcontent .tabcontainer").hide();
                $("#documentstabcontent").fadeIn('slow');
            });
            $("#userstab").click(function () {
                $("#tabul li").removeClass("ctab");
                $("#userstab").addClass("ctab");
                $("#tabcontent .tabcontainer").hide();
                $("#userstabcontent").fadeIn('slow');
            });

            function addtab(count) {
                var closetab = '<a href="" id="close' + count + '" class="close">&times;</a>';
                $("#tabul").append('<li id="t' + count + '" class="ntabs">Tab ' + count + '&nbsp;&nbsp;' + closetab + '</li>');
                $("#tabcontent").append('<div id="c' + count + '" class="tabcontainer">Tab Content ' + count + '</div>');

                $("#tabul li").removeClass("ctab");
                $("#t" + count).addClass("ctab");

                $("#t" + count).bind("click", function () {
                    $("#tabul li").removeClass("ctab");
                    $("#t" + count).addClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $("#c" + count).fadeIn('slow');
                });

                $("#close" + count).bind("click", function () {
                    // activate the previous tab
                    $("#tabul li").removeClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $(this).parent().prev().addClass("ctab");
                    $("#c" + count).prev().fadeIn('slow');

                    $(this).parent().remove();
                    $("#c" + count).remove();
                    return false;
                });
            }
        });

非常简单。只是隐藏任何不活动的选项卡内容。添加新选项卡时,会在“tabul”中添加新的

  • ,并在“tabContent”中添加新的
    。前四个选项卡是静态的,永远不会关闭(这就是为什么它们在开始时静态添加的原因)。
  • 我的问题是刷新页面时选项卡的持久性,我想保持会话。解决这个问题的正确方法是什么?我可以使用 JQ Cookie 插件吗?如果是这样怎么办?

    I have a simple tab setup using jquery (and ASP.NET MVC3 Razor engine).
    Here is the html:

    <ul id="tabul">
        <li id="litab" class="ntabs add"><a href="" id="addtab">+</a></li>
        <li id="hometab" class="ntabs">Home</li>
        <li id="componentstab" class="ntabs">Components</li>
        <li id="documentstab" class="ntabs">Documents</li>
        <li id="userstab" class="ntabs">Users</li>
    </ul>
    <div id="tabcontent">
        <div id="hometabcontent" class="tabcontainer">
            @{
                Html.RenderPartial("GetTest1Tab");
            }
        </div>
        <div id="componentstabcontent" class="tabcontainer" style="display: none;">
            @{
                Html.RenderPartial("GetTest2Tab");
            }
        </div>
        <div id="documentstabcontent" style="display: none;" class="tabcontainer">
            @{
                Html.RenderPartial("GetTest3Tab");
            }    
        </div>
        <div id="userstabcontent" style="display: none;" class="tabcontainer">
            @{
                Html.RenderPartial("GetTest4Tab");
            }
        </div>
    </div>
    

    and here is the JQuery:

            $(function () {
                var total_tabs = 0;
    
                $("#tabcontent .tabcontainer").hide();
                $("#hometabcontent").fadeIn('slow');
    
                $("#addtab, #litab").click(function () {
                    total_tabs++;
                    $("#tabcontent .tabcontainer").hide();
                    addtab(total_tabs);
                    return false;
                });
                $("#hometab").click(function () {
                    $("#tabul li").removeClass("ctab");
                    $("#hometab").addClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $("#hometabcontent").show();
                    $("#hometabcontent").children().show();
                });
    
                $("#componentstab").click(function () {
                    $("#tabul li").removeClass("ctab");
                    $("#componentstab").addClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $("#componentstabcontent").fadeIn('slow');
                });
                $("#documentstab").click(function () {
                    $("#tabul li").removeClass("ctab");
                    $("#documentstab").addClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $("#documentstabcontent").fadeIn('slow');
                });
                $("#userstab").click(function () {
                    $("#tabul li").removeClass("ctab");
                    $("#userstab").addClass("ctab");
                    $("#tabcontent .tabcontainer").hide();
                    $("#userstabcontent").fadeIn('slow');
                });
    
                function addtab(count) {
                    var closetab = '<a href="" id="close' + count + '" class="close">×</a>';
                    $("#tabul").append('<li id="t' + count + '" class="ntabs">Tab ' + count + '  ' + closetab + '</li>');
                    $("#tabcontent").append('<div id="c' + count + '" class="tabcontainer">Tab Content ' + count + '</div>');
    
                    $("#tabul li").removeClass("ctab");
                    $("#t" + count).addClass("ctab");
    
                    $("#t" + count).bind("click", function () {
                        $("#tabul li").removeClass("ctab");
                        $("#t" + count).addClass("ctab");
                        $("#tabcontent .tabcontainer").hide();
                        $("#c" + count).fadeIn('slow');
                    });
    
                    $("#close" + count).bind("click", function () {
                        // activate the previous tab
                        $("#tabul li").removeClass("ctab");
                        $("#tabcontent .tabcontainer").hide();
                        $(this).parent().prev().addClass("ctab");
                        $("#c" + count).prev().fadeIn('slow');
    
                        $(this).parent().remove();
                        $("#c" + count).remove();
                        return false;
                    });
                }
            });
    

    It's pretty simple. Just hides any tab content that isn't active. When a new tab is added, a new <li> is added in "tabul" and a new <div> is added in "tabContent". The first four tabs are static and will not ever be closed (which is why they are statically added in the beginning).

    My question is on persistence of the tabs when the page is refreshed, I want to maintain a session. What would the correct way of going about this be? Could I use the JQ Cookie plugin? If so how?

    如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

    扫码二维码加入Web技术交流群

    发布评论

    需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
    列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文