VueRouter基础01

开始

  1. 引入vue和vue-router
<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>
// 0. 如果使用模块化机制编程,導入Vue和VueRouter,要调用 Vue.use(VueRouter)

// 1. 定义(路由)组件。
const Foo = { template: '<div>foo</div>' }
const Bar = { template: '<div>bar</div>' }

// 2. 定义路由
const routes = [
  { path: '/foo', component: Foo },
  { path: '/bar', component: Bar }
]

// 3. 创建 router 实例,然后传 `routes` 配置
const router = new VueRouter({
  routes // (缩写)相当于 routes: routes
})
// 4. 创建和挂载根实例。
const app = new Vue({
  router
}).$mount('#app')

动态路由匹配

案例:即使路由中,某些值不同,但是可能还是需要使用同一路由

模式 匹配路径
/user/:username /user/evan
/user/:username/post/:post_id /user/evan/post/123
// 此处模板字符中参数,是和path相关联的组件
// 通过 $route.params.username 获取,还有 $route.hash,$route.query
const User = {
    template: `<p>{{ $route.params.username }}</p>`
}
// 通过动态路由,不同的路由可以跳转相同的页面
const routes = [
    {
        path: '/user/:username',
        component: User
    }
]
const router = new VueRouter({
    routes
});
const vm = new Vue({
    router
}).$mount('#app');

关于 router,routes, route

  1. 路由配置的时候使用的是routes
  2. vm 上挂载时使用的是router
  3. 在组件中获取路由对象$route

响应路由参数的变化

  1. 当使用路由参数时,从 /user/foo 导航到 user/bar,原来的组件实例会被复用。但是,组件生命周期的钩子函数将不会被调用,此时,要对路由参数的变化做出响应,可以使用watch在组件中监视$route
const user = {
    template: '<p> $route.params.username </p>',
    watch: {
        '$route' (to,from) {

        }
    }
}
  1. 还可以使用,beforeRouteUpdate监听
// 具体的使用,之后有详细介绍
const user = {
    template: '<span>{{ $route.param.user }}</span>',
    beforeRouteUpdate: function (to,from,next) {
        // 响应路由变化,不要忘了用next()方法
    }
}

嵌套路由

有事在模板中依旧会有router-view元素,即嵌套路由

  1. 模板大致是这样的
<div id="app">
  <router-view></router-view>
</div>
const User = {
  template: `
    <div class="user">
      <h2>User {{ $route.params.id }}</h2>
      <router-view></router-view>
    </div>
  `
}
  1. 因此在配置路由的时候,需要使用新项,children。当/user/foo的时候,如果想要被嵌套的路由也有所显示,需要进行配置。
const routes = [
    {
        path: '/user/:id',
        component: User,
        children: [
            {
                // 当/user/:id匹配成功,userHome 会显示在 User 的 router-view 中
                // 如果没有配置该项,被嵌套的路由是不会渲染任何东西的
                path: '',
                component: UserHome
            }
        ]
    }
]

编程式导航

编程式导航是在Vue实例中使用this.$router对象,注意使用的不是在组件中使用的$route

  1. 导航一共有三种方式
  • this.$router.push()
  • this.$router.replace()
  • this.$router.go()
  1. push 和 replace 的参数相同,方式稍有不同
  • path,字符串,当有path时,params不起作用
  • name,字符串,结合params使用,需要在定义路由的时候加上name
  • params,对象
  • query,对象
// 使用模板字符串结合变量
router.push({ path: `/user/${userId}` }) 
// /home?username=yf&userId=19
router.push({
    path:'home',
    params: {
        username: 'yf',
        userId: 19
    }
});

router.replace(location)

router.go(n)

命名路由

使用命名路由,方便使用

// 定义的时候使用命名路由
const router = new VueRouter({
    routes:[
        {
            path: '/user/:userId',
            // 定义的时候加上 name
            name: 'user',
            component: User
        }
    ]
})
// 链接的时候使用命名路由
router.push({name:'user',params: { userId: 123 }});
<!--链接的时候使用命名路由-->
<router-link to='{name:"user",params:{userId: 123}}'></router-link>

命名视图

命名视图使用的场景,当一个页面中有多个router-view,是并列关系。比如,页面中左边的导航栏有一个router-view,右边显示部分有一个router-view。那么,需要为每个router-view添加一个name。同时,routes中component选项需要改变components

const routes = [
    {
        path: '/',
        components: {
            // 路由没有起名字的,默认为 default
            default: Foo,
            // 有名字的
            routerViewA: Bar
        }
    }
]

重定向和别名

当访问某个页面,需要重定向的时候。别名,当路由是/b,地址栏上也确实是这个时,但实际上可能访问的是/a

// 重定向
const routes = [
    {
        path: '/a',
        redirect: '/b'
        // redirect: {name:'user'}
        // redirect: oldPath => 处理之后返回新地址
    }
]

// 别名
const routes = [
    path: '/a',
    alias: '/b'
]

HTML5 History

  1. ajax无法使用前进后退按钮还原状态,但是h5通过pushState(无刷新)实现。将一个特定的url推送到历史记录中,通过后退键,使得页面恢复到没有发送ajax请求前的状态
  2. 更多的操作需要在后台配置,官网上提供了各种后台的写法
  3. 前台只是添加一个属性mode
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,843评论 6 502
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,538评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,187评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,264评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,289评论 6 390
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,231评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,116评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,945评论 0 275
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,367评论 1 313
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,581评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,754评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,458评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,068评论 3 327
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,692评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,842评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,797评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,654评论 2 354

推荐阅读更多精彩内容