SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

japan.internet.com翻訳記事

jQueryでWeb Formsアプリケーションのフィルタリングユーザーインターフェイスを作成する(前編)

ユーザーごとに折りたたみ/展開の状態を記憶させる方法

  • X ポスト
  • このエントリーをはてなブックマークに追加

filterUItitle <div>のクリック時に折りたたみ/展開状態を切り替える

 現在の実装は確かにフィルタリングユーザーインターフェースを折りたたむようになっていますが、これを展開する方法がありません。filterUItitle <div>用のクライアントサイドのclickイベントハンドラが必要です。これでfilterUI <div>の表示(隠されている場合)と非表示(表示されている場合)を行います。また、filterUItitleのCSSクラスをexpandIconからcollapseIcon(またはその逆)に変更する必要があります。

 jQueryを使用すると、このような機能を簡単に実装できます。太字で示した5行のJavaScriptをdocumentreadyイベントハンドラに追加するだけで済むのです。

<script type="text/javascript"> 
   $(document).ready(function() { 
      $('#filterUI').hide(); 

      $('#filterUItitle').click(function() { 
         $('#filterUI').slideToggle(400); 
         $('#filterUItitle').toggleClass('expandIcon'); 
         $('#filterUItitle').toggleClass('collapseIcon'); 
      });
   }); 
</script> 

 slideToggle()関数は、フィルタリングユーザーインターフェースの表示または非表示を400ミリ秒にわたる上下の動きとしてアニメーション化します。toggleClass(className)関数は、classNameを要素に追加するか(ない場合)、または削除します(ある場合)。そのため、上記の2行のtoggleClassでは、expandIconクラスまたはcollapseIconクラスがfilterUItitle <div>から削除され、他方のクラスが追加されます。

 これで完了です。実際の動作を確認するには、本稿のサンプルファイルをダウンロードしてください。

これからの課題

 ここで実装した機能には1つ問題があります。それは、ページが表示された時点でフィルタリングユーザーインターフェースがいつも折りたたまれた状態になっていることです。つまり、ユーザーがフィルタリングインターフェースを展開し、いったんそのページの表示をやめてから再び表示した場合に、フィルタリングインターフェースを改めて展開する必要があるということです。同様に、ページ上でのあらゆるポストバック(フィルタボタンのクリックやグリッドのソートなど)によってフィルタリングインターフェースが折りたたまれることになります。UpdatePanelを使用すれば、ポストバックを超えてフィルタリングインターフェースの折りたたみ/展開状態を維持することはできますが、複数のページ要求にまたがってユーザーの折りたたみ/展開選択が記憶されるわけではありません。

 幸い、ちょっとしたAJAXの機能を利用すれば、ユーザーセッションの間じゅう折りたたみ/展開状態を記憶できます。この記事の後編では、このような機能の追加方法を説明します。

 ではそのときまで、ハッピープログラミング!

参考資料

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
japan.internet.com翻訳記事連載記事一覧

もっと読む

この記事の著者

japan.internet.com(ジャパンインターネットコム)

japan.internet.com は、1999年9月にオープンした、日本初のネットビジネス専門ニュースサイト。月間2億以上のページビューを誇る米国 Jupitermedia Corporation (Nasdaq: JUPM) のニュースサイト internet.comEarthWeb.com からの最新記事を日本語に翻訳して掲載するとともに、日本独自のネットビジネス関連記事やレポートを配信。

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

Scott Mitchell(Scott Mitchell)

http://www.4guysfromrolla.com/ScottMitchell.shtml

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/4604 2009/12/14 14:00

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング