美文网首页
前端路由化

前端路由化

作者: zjh111 | 来源:发表于2018-03-19 21:21 被阅读0次

    路由简单来说,就是根据用户输入的网址path将页面转到相应的页面
    这个任务通常是交给服务端做,但前端也可以做一些

    1 通过锚点记录信息 直接跳转打要看的地方

    <!doctype html>
    <html lang="zh-Hans">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport"
              content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>前端路优化</title>
    <style>
    div > .nav> li{}
    div > .nav > li.active{background:red;}
    div > .content > li{display:none;}
    div > .content > li.active{display:block;}
    </style>
    </head>
    
    <body>
    
    <div>
    <ol class="nav">
    <li><a href="#0"> nav0</a></li>
    <li><a href="#1"> nav1</a></li>
    </ol>
    
    <ol class="content">
    <li class="active">content0</li>
    <li>content1</li>
    </ol>
    </div>
    
    <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.slim.js"></script>
    <script>
    selectTab()
    
    window.onhashchange = (e)=>{
    selectTab()
    }
    
    function selectTab(){
        let index = location.hash || '#0'
        index = index.substring(1)
        $('div > .nav >li').eq(index).addClass('active')
            .siblings().removeClass('active')
        $('div > .content >li').eq(index).addClass('active')
            .siblings().removeClass('active')
    }
    </script>
    </body>
    </html>
    

    但是如果用户点开了“nav1”,此时有这样一个锚点

    <a href="#">回到顶部</a>
    

    锚点就被更改了,但还显示“nav1”,再复制链接打开就会和想分享的地方不一样
    当然如果给整个页面“#”都是控制显示的地方就可以用这种方法。

    2 使用pushState 无刷新更改地址栏

    <div>
    <ol class="nav">
    <li><a href="/nav0"> nav0</a></li>
    <li><a href="/nav1"> nav1</a></li>
    </ol>
    
    <ol class="content">
    <li class="active">content0</li>
    <li>content1</li>
    </ol>
    </div>
    
    <script>
    selectTab()
    //页面被用户打开时根据pathname直接定位到相应内容
    
    $('div').on('click','.nav > li > a',(e)=>{
        e.preventDefault()
        let a =e.currentTarget
        let path = a.getAttribute('href')
        window.history.pushState(null,null,path)
        selectTab()
        })
    
    function selectTab(){
        let index = location.pathname.substring(1) || 'nav0'
        index = index.substring(3)
        $('div > .nav >li').eq(index).addClass('active')
            .siblings().removeClass('active')
        $('div > .content >li').eq(index).addClass('active')
            .siblings().removeClass('active')
    }
    //没有向服务器发新请求但网址已经到了/nav1
    
    //当用户直接输入网址时,通过后台将’/nav1‘页面转
    到’/‘页面
    </script>
    

    3使用Vue-router

    html

    <script src="https://unpkg.com/vue/dist/vue.js"></script>
    <script src="https://unpkg.com/vue-router/dist/vue-router.js"></script>
    
    <div id="app">
      <h1>Hello App!</h1>
      <p>
        <!-- 使用 router-link 组件来导航. -->
        <!-- 通过传入 `to` 属性指定链接. -->
        <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
        <router-link to="/foo">Go to Foo</router-link>
        <router-link to="/bar">Go to Bar</router-link>
      </p>
      <!-- 路由出口 -->
      <!-- 路由匹配到的组件将渲染在这里 -->
      <router-view></router-view>
    </div>
    

    js

    // 0. 如果使用模块化机制编程,导入Vue和VueRouter,要调用 Vue.use(VueRouter)
    
    // 1. 定义(路由)组件。
    // 可以从其他文件 import 进来
    const Foo = { template: '<div>foo</div>' }
    const Bar = { template: '<div>bar</div>' }
    
    // 2. 定义路由
    // 每个路由应该映射一个组件。 其中"component" 可以是
    // 通过 Vue.extend() 创建的组件构造器,
    // 或者,只是一个组件配置对象。
    // 我们晚点再讨论嵌套路由。
    const routes = [
      { path: '/foo', component: Foo },
      { path: '/bar', component: Bar }
    ]
    
    // 3. 创建 router 实例,然后传 `routes` 配置
    // 你还可以传别的配置参数, 不过先这么简单着吧。
    const router = new VueRouter({
      routes // (缩写)相当于 routes: routes
    //mode:history,
    //可以设置成mode:history模式,利用history.pushState API
    })
    
    // 4. 创建和挂载根实例。
    // 记得要通过 router 配置参数注入路由,
    // 从而让整个应用都有路由功能
    const app = new Vue({
      router
    }).$mount('#app')
    
    // 现在,应用已经启动了!
    

    相关文章

      网友评论

          本文标题:前端路由化

          本文链接:https://www.haomeiwen.com/subject/jkcmqftx.html