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 サイト (m.sbmmt.com) をご覧ください。