1

私はこのような状況にあります: - php ページがある - メニューを折りたたむ jQuery スクリプトがある - 折りたたまれた要素の 1 つをクリックして、php で変数を渡すことによって別のページをロードする

問題: - jQuery スクリプトもリロードされ、前の選択がキャンセルされます。

ここに例があります。「メニュー」をクリックすると、jQuery スクリプトが「コラプス」で動作しますが、「魚」リンク (またはその他) をクリックすると、ページが表示されますが、メニューが折りたたまれて表示されません。

私が達成したいこと: - あるページから別のページに移動している間、メニューを折りたたんだままにする

ここにphpコードのサンプルがあります。

echo rightMenu();
function rightMenu(){

    $r  = '';

    $r .= '<ul id="collapser"><li>Menu<ul>';
    $r .= '<li><a href="main.php?show=page1">Fish</a></li>';
    $r .= '<li><a href="main.php?show=page2">Vegetables</a></li>';
    $r .= '<li><a href="main.php?show=page3">Meat</a></li></ul>';
    $r .= '</li></ul>';

    return $r;
};

ありがとう、ミリアム

4

2 に答える 2

1

を含める場合はjQuery.cookie、Cookie を使用してそれを行うことができます。これはより簡単なはずです。

$("#collapser").click(function () {
   //change to more appropriate value
   $.cookie('autocollapse', $(this).is(":visible"), {expires: 30});
});

//initial page load
if ($.cookie('autocollapse')) {
   $("#collapser").click();
}
于 2012-12-06T15:05:46.713 に答える
0

折りたたみがクリックされると、折りたたみを示すある種のセッション変数を記録するajaxリクエストを送信できます。

//Your collapser click function
//record hidden status in data
$("#collapser").click(function () {
   if ($(this).data('hidden')) {
      $(this).slideDown().data('hidden', false);
   }
   else {
      $(this).slideUp().data('hidden', true);
   }
   //record hidden (collapsed) status on the server
   $.post('/record-collapser-hide.php', {'hidden': $(this).data('hidden')});
});

//On initial page load, collapse if #autocollapse is in the DOM
//Added by PHP code below
if ($("#autocollapse").length) {
   $("#collapser").data('hidden', false).click();
}


//--- record-collapser-hide.php ---
session_start();
$_SESSION['collapsercollapsed'] = isset($_POST['hidden']) ? $_POST['hidden'] : 0;


//--- function rightMenu() ---
...
$r .= '</li></ul>';
if (isset($_SESSION['collapsercollapsed']) && $_SESSION['collapsercollapsed']) {
   $r .= "<span style='display: none' id='autocollapse'>&nbsp;</span>";
}

注:このコードはそのままでは機能しない可能性がありますが、基本的な考え方に従うことができるはずです。

于 2012-12-06T14:18:55.597 に答える