前端路由的两种实现

转载自  http://www.jianshu.com/p/c9de1924d215

1、原理浅析

  • hash模式
    如果a标签的href属性以"#"开头,那么当点击这个a标签时就会触发hashchange事件,在该事件处理函数中可以做很多事,比如发ajax请求,进行DOM操作替换页面等。
  • history模式
    hisroty模式相比hash模式,是一种比较新的路由模式,其浏览器兼容性如下:

pushState浏览器兼容性

原理就是利用history.pushState(state,null,url)更新浏览器url地址

2、具体实现

Talk is easy,show you the Code!

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Hash Test</title>
</head>
<body>
    <a href="#1">#1</a>
    <a href="#2">#2</a>
    <div id="content"></div>
    <script type=‘text/js-template‘ class="test" id="1">第一页</script>
    <script type=‘text/js-template‘ class="test" id="2">第二页</script>
    <script type="text/javascript">
        //1、选取元素
        var aElm=document.getElementsByTagName(‘a‘);
        var array=[].slice.call(aElm)
        var content=document.getElementById(‘content‘)
        //2、特性检测,如果支持history模式就用history,否则用hash模式
        if (history&&history.pushState) {
            window.addEventListener(‘popstate‘,handlePage);
            //劫持a元素的click事件,主要是为了更新history.state的状态以及替换url,当点击url跳转时先执行onclick再触发popstate
            array.forEach(function(v){
                v.onclick=function(event){
                    var path=event.target.hash.split("#")[1];
                    var newUrl=location.href.split(‘#‘)[0]+‘\/‘+path;
                    history.pushState({current:path},null,newUrl)
                }
            })
        } else {
            window.addEventListener(‘hashchange‘,handlePage);
        }
             //3、统一使用handlePage作为两种模式的事件处理器
        function handlePage(){
            if (history&&history.pushState) {
                var current=history.state&&history.state.current||‘1‘;
                render(current)
            } else {
                var hash=location.hash||‘#1‘;
                render(hash,true)
            }
            function render(selector,isHashMode){
                var hashMode=isHashMode&&true;
                var select=‘‘;
                if (hashMode) {
                    select=selector.split(‘#‘)[1];
                } else {
                    select=selector||history.state.current
                }
                var toPage=document.getElementById(select);
                content.innerHTML=toPage.innerHTML;
            }
        }
        handlePage();
    </script>
</body>
</html>

3、需要注意的地方

  • pushState的第三个参数url是不能跨域的
时间: 2024-11-05 02:37:24

前端路由的两种实现的相关文章

前端路由的两种实现方式

什么是路由? 路由是根据不同的 url 地址展示不同的内容或页面 早期的路由都是后端直接根据 url 来 reload 页面实现的,即后端控制路由. 后来页面越来越复杂,服务器压力越来越大,随着 ajax(异步刷新技术) 的出现,页面实现非 reload 就能刷新数据,让前端也可以控制 url 自行管理,前端路由由此而生. 单页面应用的实现,就是因为前端路由. 前端路由实现 1.Pjax(PushState + Ajax) 原理:利用ajax请求替代了a标签的默认跳转,然后利用html5中的AP

vue路由的两种模式配置以及history模式下面后端如何配置

vue路由的两种模式配置以及history模式下面后端如何配置 1.hash ——即地址栏URL中的#符号.hash 虽然出现URL中,但不会被包含在HTTP请求中,对后端完全没有影响,因此改变hash不会重新加载页面.2.history ——利用了HTML5 History Interface 中新增的pushState() 和replaceState() 方法.需要特定浏览器支持history模式,会出现404 的情况,需要后台配置.3.hash模式下,仅hash符号之前的内容会被包含在请求

用easyui从servlet传递json数据到前端页面的两种方法

用easyui从servlet传递json数据到前端页面的两种方法 两种方法获取的数据在servlet层传递的方法相同,下面为Servlet中代码,以查询表中所有信息为例. //重写doGet方法 protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stu

vue路由的两种模式,hash与history

对于Vue 这类渐进式前端开发框架,为了构建SPA(单页面应用),需要引入前端路由系统,这也就是Vue-router存在的意义.前端路由的核心,就在于——— 改变视图的同时不会向后端发出请求. 一.为了达到这个目的,浏览器提供了以下两种支持: 1.hash ——即地址栏URL中的#符号(此hsah 不是密码学里的散列运算). 比如这个URL:http://www.abc.com/#/hello, hash 的值为#/hello.它的特点在于:hash 虽然出现URL中,但不会被包含在HTTP请求

Linux中增加软路由的两种方法/删除的方法

第一种: route add -net 172.16.6.0 netmask 255.255.255.0 gw 172.16.2.254 dev eth0 route del gw 172.16.2.254 route del -net 172.16.86.0/24 route /* 显示当前路由表 */ 第二种: 实现的功能和上面的一样 ip route add 172.16.6.0/24 via 172.16.2.254 dev eth0 ip route del gw 172.16.2.2

vue路由的两种模式,hash与history的区别

1.直观区别: hash模式url带#号,history模式不带#号. 2.深层区别: hash模式url里面永远带着#号,我们在开发当中默认使用这个模式. 如果用户考虑url的规范那么就需要使用history模式,因为history模式没有#号,是个正常的url适合推广宣传 功能也有区别,比如我们在开发app的时候有分享页面,那么这个分享出去的页面就是用vue或是react做的, 咱们把这个页面分享到第三方的app里,有的app里面url是不允许带有#号的,所以要将#号去除那么就要使用hist

前端路由

前端路由的两种实现方式: 1. location.hash + hashchange function Router(){ this.curUrl = ''; this.routes = {}; } Router.prototype = { route(path, callback){ this.routes[path] = callback || function(){} }, refresh(){ this.curUrl = location.hash.slice(1) || ''; thi

前端路由机制

前端路由:在应用使用期间不会重新加载,提高用户体验,减低网速要求,界面展开快.前后端分离方便开发 目前前端路由有两种实现方法: 利用url的hash,当浏览器url的锚点部分发生改变,不会刷新页面的原理 利用h5中的history,通过监听opostate事件,利用pushstate或replacestate实现 原生router/hash版 html: 123456 <ul> <li><a href="#/home">home</a>&

vue-learning:38 - router - 前端路由的发展

前端路由的发展 参考博客 前端路由是什么东西? 什么是路由 在jQuery时代,我们使用<a href="https://www.example.com/example/home.html">实现页面切换. 其响应过程是这样的 1.浏览器发出请求 2.服务器监听到指定端口的请求,并解析url路径 3.浏览器根据数据包的Content-Type来决定如何解析数据 4.根据服务器的路由配置,返回相应信息(比如返回html文件的字串,也可以是 json 数据,图片等) 5.浏览器