Riot의 라우팅 시스템은 hashChange의 [Anchor Point Change]를 기반으로 합니다. 앵커 포인트 변경 사항을 모니터링하는 방법은 두 가지가 있습니다:
riot.route 및 riot.route.exec
둘 사이의 차이점은 다음과 같습니다.
1. 그 이후에는 한 번만 실행합니다
2. 경로 페이지가 로드된 후에는 자동으로 실행되지 않습니다
3. 경로만 실행됩니다. >
앵커 포인트가 변경된 후 사용법은 동일하지만 실행 시점이 다릅니다. 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"} });