用js写的一个路由

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用js写的一个路由相关的知识,希望对你有一定的参考价值。

前几天在院子里看了一个大牛用js写了一个路由的,有一句代码一直不知道怎么回事,后来就自己写了一个,写的比较的粗糙,我觉得把面向对象的思想都搞得乱七八糟的,不过功能实现了.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>js实现路由</title>
</head>
<body>
    < a href=" " >white</ a>
    < a href="#/green" >green</ a>
    < a href="#/blue" >blue</ a>
    < a href="#/yellow" >yellow</ a>
</body>
</html>

<script>

    function Route(){
    }
    Route.prototype.open=function(route,callback){
        var arr={};
        arr[route]=callback;

        window.addEventListener(‘hashchange‘,function(){
            var temp=window.location.hash;
            for(var i in arr){
                if(i==temp.slice(1,temp.length)){
                    arr[i]();
                }
            }
        })
    }
    window.Route=new Route();


    function change(color){
        var body=document.getElementsByTagName(‘body‘)[0];
        body.style.backgroundColor=color;
        console.log(color);
    }
    
    Route.open(‘/‘,function(){
        change(‘‘);
    });
    Route.open(‘/green‘,function(){
        change(‘green‘);
    });
    Route.open(‘/blue‘,function(){
        change(‘blue‘);
    });
    Route.open(‘/yellow‘,function(){
        change(‘yellow‘);
    });

</script>
  

以上是关于用js写的一个路由的主要内容,如果未能解决你的问题,请参考以下文章

Express实战 - 应用案例- realworld-API - 路由设计 - mongoose - 数据验证 - 密码加密 - 登录接口 - 身份认证 - token - 增删改查API(代码片段

VSCode自定义代码片段11——vue路由的配置

VSCode自定义代码片段11——vue路由的配置

VSCode自定义代码片段11——vue路由的配置

Vue 路由懒加载

回归 | js实用代码片段的封装与总结(持续更新中...)