首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JQuery选项卡选择问题?

JQuery选项卡选择问题?
EN

Stack Overflow用户
提问于 2010-03-25 07:12:54
回答 2查看 424关注 0票数 0

我是JQuery的新手,我想知道当用户重新加载网页时,如何保持任何选项卡处于选中状态?我需要更改代码的哪一部分?

这是我的JQuery代码。

代码语言:javascript
复制
$(document).ready(function() {

    //When page loads...
    $(".form-content").hide(); //Hide all content
    var firstMenu = $("#home-menu ul li:first");
    firstMenu.show();
    firstMenu.find("a").addClass("selected-link"); //Activate first tab
    $(".form-content:first").show(); //Show first tab content

    //On Click Event
    $("#home-menu ul li").click(function() {

        $("#home-menu ul li a").removeClass("selected-link"); //Remove any "selected-link" class
        $(this).find("a").addClass("selected-link"); //Add "selected-link" class to selected tab
        $(".form-content").hide(); //Hide all tab content

        var activeTab = $(this).find("a").attr("href"); //Find the href attribute value to identify the selected-link tab + content
        $(activeTab).fadeIn(); //Fade in the selected-link ID content
        return false;
    });

});

下面是XHTML代码。

代码语言:javascript
复制
<div id="home-menu">
    <ul>
        <li><a href="#personal-info-form" title="Personal Info Form Link">Personal Info</a></li>
        <li><a href="#contact-info-form" title="Contact Info Form Link">Contact Info</a></li>
    </ul>
</div>


<div>

    <div id="personal-info-form" class="form-content">

    <h2>Personal Information</h2>
        <form method="post" action="index.php">
            <fieldset>
                <ul>
                    <li><label for="first_name">First Name: </label><input type="text" name="first_name" id="first_name" size="25" class="input-size" value="<?php if(!empty($first_name)){ echo $first_name; } ?>" /></li>
                    <li><label for="middle_name">Middle Name: </label><input type="text" name="middle_name" id="middle_name" size="25" class="input-size" value="<?php if(!empty($middle_name)){ echo $middle_name; } ?>" /></li>
                    <li><label for="last_name">Last Name: </label><input type="text" name="last_name" id="last_name" size="25" class="input-size" value="<?php if(!empty($last_name)){ echo $last_name; } ?>" /></li>
                    <li><label for="password-1">Password: </label><input type="password" name="password1" id="password-1" size="25" class="input-size" /></li>
                    <li><label for="password-2">Confirm Password: </label><input type="password" name="password2" id="password-2" size="25" class="input-size" /></li>
                    <li><input type="submit" name="submit" value="Save Changes" class="save-button" />
                    <input type="submit" name="submit" value="Preview Changes" class="preview-changes-button" /></li>
                </ul>
            </fieldset>
        </form>

    </div>


    <div id="contact-info-form" class="form-content">

    <h2>Contact Information</h2>
        <form method="post" action="index.php" id="contact-form">
            <fieldset>
                <ul>
                    <li><label for="address">Address 1: </label><input type="text" name="address" id="address" size="25" class="input-size" value="<?php if (isset($_POST['address'])) { echo $_POST['address']; } else if(!empty($address)) { echo $address; } ?>" /></li>
                    <li><label for="address_two">Address 2: </label><input type="text" name="address_two" id="address_two" size="25" class="input-size" value="<?php if (isset($_POST['address_two'])) { echo $_POST['address_two']; } else if(!empty($address_two)) { echo $address_two; } ?>" /></li>
                    <li><label for="city_town">City/Town: </label><input type="text" name="city_town" id="city_town" size="25" class="input-size" value="<?php if (isset($_POST['city_town'])) { echo $_POST['city_town']; } else if(!empty($city_town)) { echo $city_town; } ?>" /></li>
                    <li><input type="submit" name="submit" value="Save Changes" class="save-button" />
                        <input type="hidden" name="contact_info_submitted" value="true" />
                    <input type="submit" name="submit" value="Preview Changes" class="preview-changes-button" /></li>
                </ul>
            </fieldset>

        </form>

    </div>

</div>
EN

回答 2

Stack Overflow用户

发布于 2010-03-25 07:20:09

您必须检查URL中是否存在任何#your-tab- in作为锚点(或散列)。一种方法是:

代码语言:javascript
复制
var m = window.location.href.match(/#(.+)$/);
if (m && m[1]) $('#home-menu ul a[href=#' + m[1] + ']').parent().click();
票数 0
EN

Stack Overflow用户

发布于 2010-03-25 07:32:55

一种选择是使用cookie来存储所单击选项卡的值。有一个jQuery插件可以帮助你轻松做到这一点。

http://www.stilbuero.de/2006/09/17/cookie-plugin-for-jquery/

我个人更喜欢这比任何网址短语...with插件,比方说它的标签id 2你只需要在你的onclick中这样做…

代码语言:javascript
复制
$.cookie("mySelectedTab", "2"); //set

然后,当您在$(document).ready中拉回cookie值以设置所需的选项卡时。

代码语言:javascript
复制
$.cookie("example"); // read it back
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2512124

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档