現在、アプリケーションの1つでPathJSを使用しています。それは私が下した最高の決断でした。特定のユースケースについては、 HTML5の例をご覧ください。
サンプルを機能させるコードの一部(ソースから):
<script type="text/javascript">
        // This example makes use of the jQuery library.
        // You can use any methods as actions in PathJS.  You can define them as I do below,
        // assign them to variables, or use anonymous functions.  The choice is yours.
        function notFound(){
            $("#output .content").html("404 Not Found");
            $("#output .content").addClass("error");
        }
        function setPageBackground(){
            $("#output .content").removeClass("error");
        }        
        // Here we define our routes.  You'll notice that I only define three routes, even
        // though there are four links.  Each route has an action assigned to it (via the 
        // `to` method, as well as an `enter` method.  The `enter` method is called before
        // the route is performed, which allows you to do any setup you need (changes classes,
        // performing AJAX calls, adding animations, etc.
        Path.map("/users").to(function(){
            $("#output .content").html("Users");
        }).enter(setPageBackground);
       Path.map("/about").to(function(){
            $("#output .content").html("About");
        }).enter(setPageBackground);
       Path.map("/contact").to(function(){
            $("#output .content").html("Contact");
        }).enter(setPageBackground);
        // The `Path.rescue()` method takes a function as an argument, and will be called when
        // a route is activated that you have not yet defined an action for.  On this example
        // page, you'll notice there is no defined route for the "Unicorns!?" link.  Since no
        // route is defined, it calls this method instead.
        Path.rescue(notFound);
        $(document).ready(function(){
            // This line is used to start the HTML5 PathJS listener.  This will modify the
            // `window.onpopstate` method accordingly, check that HTML5 is supported, and
            // fall back to hashtags if you tell it to.  Calling it with no arguments will
            // cause it to do nothing if HTML5 is not supported
            Path.history.listen();
            // If you would like it to gracefully fallback to Hashtags in the event that HTML5
            // isn't supported, just pass `true` into the method.
            // Path.history.listen(true);
            $("a").click(function(event){
                event.preventDefault();
                // To make use of the HTML5 History API, you need to tell your click events to
                // add to the history stack by calling the `Path.history.pushState` method. This
                // method is analogous to the regular `window.history.pushState` method, but
                // wraps calls to it around the PathJS dispatched.  Conveniently, you'll still have
                // access to any state data you assign to it as if you had manually set it via
                // the standard methods.
                Path.history.pushState({}, "", $(this).attr("href"));
            });
        });
    </script>
PathJSには、ルーティングライブラリの最も必要な機能がいくつかあります。
- 軽量
- HTML5 History API、「onhashchange」メソッド、および適切な劣化をサポートします
- ルートルート、レスキューメソッド、パラメータ化されたルート、オプションのルートコンポーネント(動的ルート)、およびアスペクト指向プログラミングをサポートします
- 十分にテスト済み(./testsディレクトリで利用可能なテスト)
- すべての主要なブラウザと互換性があります(Firefox 3.6、Firefox 4.0、Firefox 5.0、Chrome 9、Opera 11、IE7、IE8、IE9でテスト済み)
- すべてのサードパーティライブラリから独立していますが、すべてのサードパーティライブラリとうまく連携します
最後のポイントが最も魅力的だと思いました。あなたはここでそれらを見つけることができます
これがお役に立てば幸いです。