美文网首页
前端路由化

前端路由化

作者: 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')

// 现在,应用已经启动了!

相关文章

  • 前端路由化

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

  • 前端路由

    2019/4/1通过记录url的变化来记录ajax的变化(ajax的标签化),从而实现前端路由。前端路由存在缺陷:...

  • 第三十一节:Vue路由:前端路由vs后端路由的了解

    1. 认识前端路由和后端路由 前端路由相对于后端路由而言的, 在理解前端路由之前先对于路由有一个基本的了解 路由:...

  • 搭建Vue项目

    初始化Vue前端项目 安装插件 封装 token.js 封装 axios 动态路由

  • 前端微服务化解决方案5 - 路由分发

    路由分发式微前端 从应用分发路由到路由分发应用 用这句话来解释,微前端的路由,再合适不过来. 路由分发式微前端,即...

  • 前端路由规范

    一 、 前端路由名和路径名命名规范 为避免路由重名和加强路由语义化,特制定此规范。 通常我们的项目中src目录中会...

  • vue - 路由模式

    1 路由的基本概念与原理 路由的本质就是对应关系; 在开发中, 路由分为前端路由和后端路由. 1.1 前端路由 概...

  • react-router-dom

    一、什么是前端路由 在我看来,前端路由和网络上的路由器功能很像。前端路由也是进行分发操作,只不过其分发的是页面跳转...

  • vue基础-路由(重要)

    前端路由的概念与原理 什么是前端路由 Hash 地址与组件之间的映射关系,前端路由可以将hash地址和组件关联起来...

  • CreateReactApp+ReactRouter4的使用

    路由基础介绍1,什么是前端路由? 路由是根据不同的 url 地址展示不同的内容或页面 前端路由就是把不同路由对应不...

网友评论

      本文标题:前端路由化

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