>  기사  >  웹 프론트엔드  >  riot.js 학습 [9] 라우팅

riot.js 학습 [9] 라우팅

黄舟
黄舟원래의
2017-01-16 16:23:351601검색

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"}
});

히스토리 API는 사용하지 않지만 링크를 수정하려면 앵커 포인트로 충분합니다.

위는 riot.js를 이용한 라우팅 학습 [9] 내용입니다. 더 많은 관련 내용은 PHP 중국어 홈페이지(www.php.cn)를 참고해주세요!


성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.