前端路由化

路由简单来说,就是根据用户输入的网址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')

// 现在,应用已经启动了!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,952评论 25 707
  • 张爱玲爱钱,她说“我喜欢钱,因为我没有吃过钱的苦,不知道钱的坏处,只知道钱的好处。” 有钱,才能让一个人活的独立。...
    节俭生活阅读 266评论 0 2
  • 立春之前,乍暖还寒,久咳未愈,晚求良方。各地微友,无私分享,暖意在心,无以言表。欲褒羹汤,无刀之炊,遂求助群,何处...
    静听玉兰花开阅读 257评论 0 1
  • 窗外漆黑、我却不敢入睡 世界漆黑、却不及我心一角的无尽深渊、 人心漆黑、世间如灰,万物无色 我仿佛拥有一切、又仿佛...
    grayWorld阅读 203评论 0 0
  • 你是什么样的人和你想成为什么样的之间的差距就是,你做了什么。
    鼗豸爻爻阅读 30评论 0 0