riot.js 学習 [9] ルーティング

黄舟
黄舟オリジナル
2017-01-16 16:23:351663ブラウズ

RiotのルーティングシステムはhashChangeの[アンカーポイント変更]に基づいています。アンカーポイントの変更を監視するには 2 つの方法があります:

riot.route と riot.route.exec

2 つの違いは次のとおりです:

1. exec はページのロード後に 1 回だけ実行されます。

2. ルートページが読み込まれた後、ルートは自動的に実行されません

3. ルートはアンカーポイントが変更された後にのみ実行されます

2 つの使い方は同じですが、実行タイミングが異なります。 exec を例に挙げてみましょう

デフォルト値は次のとおりです:

[code]// .../index.html#123/da宗熊
riot.route.exec(function(id, name){
    // id = 123, name = da宗熊
    console.log(id, name);
});

ルートのコールバックパラメータはデフォルトでは「/」で区切られています。

Riot は、ルートのデフォルト値を上書きするメソッドも提供します:

[code]// 定义路由新的取值方式: #!/user/home?id=123&name=xxx
riot.route.parser(function(path){
    // path 是 hash【除去#的那部分】 => !/user/home?id=123&name=xxx
    var raw = path.slice(1).split("?");
    var uri = raw[0],
        qs = raw[1],
        params = {};

    // 有搜索参数的话
    if(qs){
        qs.replace(/([^=&]*)=([^&])*/g, function(str, key, value){
            params[key] = value;
            return str;
        });
    };
    // 给下面riot.route.exec()和riot.route()的 第1 和 第2 个参数
    return [uri, params];
});

新しいルート監視は次のように使用できます:

[code]// 假如链接如下: #!/user/home?id=123&name=xxx
riot.route.exec(function(uri, qs){
    // uri = /user/home
    // qs = {id: 123, name: "xxx"}
});

リンクを修正するために履歴 API は使用されませんが、アンカー ポイントで十分です。

上記は、[9] riot.js によるルーティングの学習の内容です。その他の関連コンテンツについては、PHP 中国語 Web サイト (www.php.cn) をご覧ください。


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。