Ajaxで今よみがえる(^^;;-->[クロスブラウザ技術 ]DHTMLサンプル集
古籏一浩さんとのはじめての共著 発売中-->『Ajax実践テクニック』 古籏一浩/高橋 登史朗 (著)秀和システム
配本予約開始-->『入門Ajax 増補改訂版 』 高橋 登史朗 (著)ソフトバンククリエイティブ ; ISBN: 4797336242
-- リスト --
【カテゴリー】 ActionScript ( 6 ) AIR ( 2 ) AjaSQL ( 10 ) Ajax ( 575 ) Arax ( 1 ) canvas ( 10 ) CSS ( 11 ) ( 5 ) DLNA ( 1 ) Dojo ( 17 ) DOM ( 45 ) ES4 ( 4 ) Ext JS ( 2 ) 反重力物質 ( 1 ) ffAdd-on ( 1 ) Flash ( 46 ) Flash Remoting ( 11 ) FTP ( 2 ) GAF ( 9 ) Google Maps ( 119 ) GPS ( 42 ) HTTPヘッダサンプル ( 9 ) Internet ( 1 ) iPhone ( 31 ) IPv6 ( 1 ) 漫画 ( 1 ) Java ( 45 ) JavaScript ( 265 ) jKamo ( 8 ) jQchart ( 2 ) jQuery ( 111 ) jquery-ref ( 1 ) jsGadget ( 19 ) jslb_ ( 3 ) jslb_ajax ( 9 ) JSON ( 47 ) JSR223 ( 7 ) kjscmd ( 1 ) KNOPPIX ( 1 ) Linux ( 16 ) Mac ( 8 ) Memo ( 3 ) Microformats ( 2 ) Mini AJAX ( 2 ) MochiKit ( 2 ) mootools ( 3 ) Movable Type ( 57 ) MySQL ( 10 ) NewGameWeb ( 2 ) Nucleus ( 8 ) OpenAJAX ( 3 ) OpenDocument ( 1 ) OS ( 7 ) P2P ( 2 ) Perl ( 7 ) PHP ( 37 ) PostGIS ( 1 ) PostgreSQL ( 4 ) prototype.js ( 22 ) ROBOT ( 1 ) RSSリーダー ( 14 ) Ruby on Rails ( 7 ) Spry ( 6 ) SQLite ( 16 ) SQLiteWorker ( 2 ) ssh ( 1 ) SSI ( 2 ) SVG ( 15 ) TRON ( 1 ) Video ( 1 ) VML ( 1 ) Web Slice ( 1 ) Webサービス ( 98 ) widget ( 6 ) Wii ( 1 ) Wiki ( 1 ) Win ( 6 ) WSH ( 1 ) X01HT ( 29 ) XML ( 30 ) XOOPS ( 1 ) XQuery ( 2 ) XUL ( 4 ) Yahoo! UI ( 64 ) 日付入力用カレンダー ( 1 ) 『Ajax実践テクニック』 ( 1 ) 『入門 Ajax』 ( 42 ) WinTips ( 2 ) こりゃすごい ( 3 ) チューニング ( 22 ) ダイナミックロード関数 ( 7 ) リファレンス ( 18 ) ライブラリ ( 114 ) レーダー雨量表示 ( 1 ) ハード ( 23 ) ペンギン ( 2 ) ブラウザ ( 73 ) ブログでBBS ( 1 ) アクセスグラフ ( 3 ) イベント ( 2 ) カレンダーによる日付入力スクリプト ( 4 ) クロスブラウザ ( 11 ) クロスブラウザ関数 ( 7 ) スマートフォン ( 8 ) セキュリティ ( 114 ) ソフトイーサ ( 1 ) マッシュアップ ( 23 ) 暗号 ( 4 ) 映画 ( 47 ) 河川の水位グラフ ( 3 ) 回線 ( 2 ) 開発ツール ( 26 ) 牛久大仏 ( 9 ) 携帯 ( 138 ) 言語 ( 18 ) 故障 ( 3 ) 洪水警報システム ( 2 ) 今日のひと言 ( 5 ) 仕様 ( 60 ) 雑談 ( 232 ) 実装 ( 1 ) 書籍 ( 17 ) 親子ウインドウ有無の確認関数 ( 3 ) 新海誠 ( 3 )
【info】有料サポート(ベータ)限定 承り中 多忙につき、一時、新規受付停止 閉店中 /【JSサポート(仮称)】 

【info】いつもいろいろなテストなどをページ内のあちこちでやっているので、重かったり、壊れていたりするf^^;ことも多いです。実験用ですので、カオス(混沌)をあえて意図したりもしますので、標準やValidとは無縁だったりしますが、何卒、ご了承ください ( _ _ b

2007年10月25日

【jQuery】jQuery UI/Accordion

jQuery , ライブラリ , リファレンス ブックマークに追加する ブックマーク-- Buzzurl  / Hatena  / Livedoor track feed


【jQuery】Selectors を書くのに項目数が多くて場所を取りそうなので、jQuery UI Accordion を使ってみました。

jquery.jsの他にui.accordion.jsを読み込んであとはHTML+CSS指定を書くだけなので楽ちんですが、コメントでも話が出ているように、かさばるコンテンツをアコーデオンに収めると開閉動作がスクロールを伴うので、かなり読みにくいインターフェイスになってしまいます。

そこで、とりあえず、accordionへshowAllとhideAllメソッドを拡張して(しなくても良いんですけど、一応、、、^^;)チェックボックスで全開/閉できるようにしてみました。

これで、読みたいときだけ読みたい部分をクリックで引き出しのように開くか、showAllで全部開いてゆっくり見る。という使い方ができるようになりました。 その拡張ソースは下記のとおり。#jqexample .ui-accordion-bodyって埋め込んじゃってますけど(^^;まぁ、いいや。少しだけ修正。

で、更に、hideAllに不具合があったので、あっさり、showAllのみに変更。<拡張は慎重にf^^;。
    $("#jqexample").accordion({alwaysOpen: false});

    $.fn.extend( $("#jqexample").accordion , {
        showAll:function(){$("#jqexample .ui-accordion-body").fadeIn();},
        hideAll:function(){$("#jqexample .ui-accordion-body").fadeOut();}
    });

    $("#jqexample").accordion.hideAll() ;

    $("#jqshowall:checkbox").click(function(e){ 
       if($("#jqshowall:checkbox").get(0).checked){
         $("#jqexample").accordion.showAll() ;
       } else {
         $("#jqexample").accordion.hideAll() ;
       }
    });

//で、さらに修正f^^;;;

    //インスタンス作ります
    $("#jqexample").accordion({alwaysOpen: false});

    //インスタンスにメソッドを2つ追加コピーします
    $.fn.extend( $("#jqexample").accordion , {
        showAll:function(targets){$(targets).fadeIn();},
        hideAll:function(targets){$(targets).fadeOut();}
    });

    //全部フェイドアウト ここは、フェイドは無駄なのでhide()で良いかも
    $("#jqexample").accordion.hideAll("#jqexample .ui-accordion-body") ;

    //チェックボックスクリック来たら判定して2つのメソッドをトグル動作させる
    $("#jqshowall:checkbox").click(function(e){ 
       if($("#jqshowall:checkbox").get(0).checked){
         $("#jqexample").accordion.showAll("#jqexample .ui-accordion-body") ;
       } else {
         $("#jqexample").accordion.hideAll("#jqexample .ui-accordion-body") ;
       }
    });


    //インスタンス作ります
    $("#jqexample").accordion({alwaysOpen: false});

    //インスタンスのaccordionにshowAllメソッドを追加コピーします
    $.fn.extend( $("#jqexample").accordion , {
        showAll:function(target){$(target).fadeIn();}
    });

    //ボタンクリック来たらshowAllメソッドを動作させる
    $("#jqshowall:button").click(function(e){ 
         $("#jqexample").accordion.showAll("#jqexample .ui-accordion-body") ;
    });

でも、拡張使ってみたかったというだけのことなので普通は下記で良いかも(笑)。

    //インスタンス作ります
    $("#jqexample").accordion({alwaysOpen: false});

    //ボタンクリック来たら#jqexample 内の.ui-accordion-bodyをすべてfadeInする
    $("#jqshowall:button").click(function(e){ 
         $("#jqexample .ui-accordion-body").fadeIn();
    });

それにしても、jQueryだと、なんて簡単に書けるんだろう!