Vue学习笔记4--vue-router路由

vue-router前端路由

完整的基础篇笔记PDF下载,完全手打有用的话请给个赞呗Thanks♪(・ω・)ノ

路由的基本概念

本质

路由本质是对应关系

路由分类

  • 后端路由

    概念:根据用户的URL请求返回不同内容
    本质:URL请求地址与服务器资源之间的对应关系
    
  • 前端路由

    概念:根据不用的用户事件,显示不用的页面内容
    本质:用户事件和事件处理函数之间的对应关系
    

实现简单的前端路由

  • 基于URL中的hash实现(点击菜单的时候改变URL的hash,根据hash的变化控制组件的切换)
window.onhashchange = function(){
    console.log(location.hash);
}

Demo

<body>
    <div id="app">
        <a href="#/zhuye">主页</a>
        <a href="#/keji">科技</a>
        <a href="#/caijing">财经</a>
        <a href="#/yule">娱乐</a>
        
        <!-- 组件占位符 -->
        <component :is="comName"></component>
    </div>
    <script>
        const zhuye = {
            template: '<h1>主页信息</h1>'
        }
        const keji = {
            template: '<h1>科技信息</h1>'
        }
        const caijing = {
            template: '<h1>财经信息</h1>'
        }
        const yule = {
            template: '<h1>娱乐信息</h1>'
        } 
        const vm = new Vue({
            el: '#app',
            data: {
                comName: 'zhuye'
            },
            components: {
                zhuye,
                keji,
                caijing,
                yule
            }

        });
        
        //监听页面hash值的变化
        window.onhashchange = function(){
            vm.comName = location.hash.slice(2);
        }
         
    </script>
</body>

vue-router的基本使用

Vue.js官方的路由器,和Vue.js核心深度集成

功能

  • 支持H5的历史模式和hash模式
  • 支持嵌套路由
  • 支持路由参数
  • 支持编程式路由
  • 支持命名路由

使用步骤

  • 引入相关库文件

    <!-- 引入vue.js -->
    <script src="js/vue.js"></script>
    <!-- 引入vue-router.js -->
    <script src="js/vue-router.js"></script>
    
  • 添加路由链接

    <!-- router-link 默认渲染为a标签 -->
    <!-- to 属性渲染为href -->
    <!-- to 属性的值渲染为#开头的hash地址 -->
    <router-link to="/user">User</router-link>
    
  • 添加路由填充位

    <!-- 路由填充位也称为路由占位符 -->
    <!-- 将来通过路由规则匹配到的组件,将会被渲染到 router-view 所在位置-->
    <router-view></router-view>
    
  • 定义路由组件

    var User = {
        template: '<h1>User</h1>'
    }
    var Register = {
        template: '<h1>Register</h1>'
    }
    
  • 配置路由规则并创建路由实例

    const router = new VueRouter({
        //存放路由规则的数组
        routes: [
            //每个路由规则是一个配置对象,至少包含path和component两个属性
            //path: 当前路由规则匹配的hash地址
            //component: 便是当前路由规则对应的组件
            {path:'/user',component: User},
            {path: '/register',component: Register}
        ]
    })
    
    
  • 把路由挂载到Vue实例中

    const vm = new Vue({
        el: '#app',
        data: {
            comName: 'zhuye'
        },
        //配置
        //router: router 对应一致时可以简写
        router
    
    });
    

路由重定向

用户在访问地址A的时候,强制用户跳转到地址C,从而展示特定页面

默认进入页面地址为:http://127.0.0.1:5500/index.html#/

希望进入: http://127.0.0.1:5500/index.html#/user

使用redirect属性配置

const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        {path: '/', redirect: '/user'},
        {path:'/user',component: User},
        {path: '/register',component: Register}
    ]
})

vue-router嵌套路由

分析

  • 点击父级路由链接显示模板内容
  • 模板内容内容中又有自己路由链接
  • 点击子级路由链接显示子级模板内容

步骤

  • 创建父级路由链接和父级路由填充位
<router-link to="/user">User</router-link>
<router-link to="/register">Register</router-link>

<!-- 路由填充位也称为路由占位符 -->
<!-- 将来通过路由规则匹配到的组件,将会被渲染到 router-view 所在位置-->
<router-view></router-view>
  • 定义路由组件
var User = {
    template: '<h1>User 组件</h1>'
}
var Register = {
    template:  `
            <div>
                <h1>Register 组件</h1>
                <hr/>
                <router-link to="/register/tab1">Tab1</router-link>
                <router-link to="/register/tab2">Tab2</router-link>

                <!-- 子路由填充位 -->
                <router-view></router-view>
            </div>`
}
var Tab1 = {
    template: '<h2>Tab1</h2>'
}
var Tab2 = {
    template: '<h2>Tab1</h2>'
}
  • 嵌套路由配置
const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        {path: '/', redirect: '/user'},
        {path:'/user',component: User},
        {
            path: '/register',
            component: Register,
            //嵌套子路由
            children: [
                 {path: '/register/tab1',component: Tab1},
                 {path: '/register/tab2',component: Tab2}
            ]
        }
    ]
})
  • Vue实例中挂载router
const vm = new Vue({
    el: '#app',
    data: {
        comName: 'zhuye'
    },
    //配置
    //router: router 对应一致时可以简写
    router

});

vue-router动态匹配路由

基本用法

 const router1 = new VueRouter({
     routers: [
         //动态路由路径参数 冒号开头
         {path: '/user/:id',component: User}
     ]
 })

组件中获取id值

const User = {
    //通过 $route.params 获取参数
    template: '<div>User {{ $route.params.id }}</div>'
}

Demo

  • 路由链接和路由填充位
<router-link to="/user/1">User1</router-link>
<router-link to="/user/2">User2</router-link>
<router-link to="/user/3">User3</router-link>

<!-- 路由填充位也称为路由占位符 -->
<!-- 将来通过路由规则匹配到的组件,将会被渲染到 router-view 所在位置-->
<router-view></router-view>
  • 组件
const User = {
    //通过 $route.params 获取参数
    template: '<div>User {{$route.params.id}} 组件</div>'
}
  • 定义路由实例
const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        {path: '/', redirect: '/user'},
        //动态路由路径参数 冒号开头
        {path:'/user/:id',component: User},
    ]
})
  • Vue实例中挂载router
const vm = new Vue({
    el: '#app',
    data: {

    },
    //配置
    //router: router 对应一致时可以简写
    router

});

传参方式

  • $route.params : 与对应路由高度耦合,不灵活
  • props:组件和路由解耦
props 使用
  • 定义props的值为布尔类型
const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        //props 值设置为true route.params 将会被设置为组件属性
        {path: '/', redirect: '/user'},
        //动态路由路径参数 冒号开头
        {path:'/user/:id',component: User, props: true},
    ]
})
  • 组件获取使用props获取属性
 const User = {
     //使用props获取路由参数
     props: ['id'],
     //通过 $route.params 获取参数
     template: '<div>User {{ id }} 组件</div>'
 }

props还可以是一个对象

const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        //props 值设置为true route.params 将会被设置为组件属性
        {path: '/', redirect: '/user'},
        //动态路由路径参数 冒号开头
        {path:'/user/:id',component: User, props: {uname: 'test', age: 11 }},
    ]
})

注:此时id值无法访问

使用id的值方式如下:

const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        //每个路由规则是一个配置对象,至少包含path和component两个属性
        //path: 当前路由规则匹配的hash地址
        //component: 便是当前路由规则对应的组件
        //props 值设置为true route.params 将会被设置为组件属性
        {path: '/', redirect: '/user'},
        //动态路由路径参数 冒号开头
        {
            path:'/user/:id',
            component: User, 
            //此时id的值和usname的值等都可使用
            props: route => ({uname: 'lisi' , age: 20, id: route.params.id })
        },
    ]
})                                                                                                                                                             

vue-router命名路由

概念

为了更加方便的表示路由的路径,给路由规则起一个别名,即为:命名路由

const router = new VueRouter({
    //存放路由规则的数组
    routes: [
        
        {path: '/', redirect: '/user'},
        //动态路由路径参数 冒号开头
        {
            name: 'user',
            path:'/user/:id',
            component: User, 
            props: true
        }
    ]
})   

页面跳转使用命名路由(to属性要添加 :)

<router-link :to="{ name: 'user', params: {id: 123} }">User1</router-link

vue-router编程式导航

常见页面导航方式

  • 声明式导航
<a></a>
<router-link></router-link>
  • 编程式导航:通过调用JavaScript的API实现导航方式
location.href=

Vue中的编程式导航

this.$router.push('hash地址')
//n是历史记录 1:表示历史记录中前进1位 -1:表示历史记录中后退1位
this.$router.go(n)

Demo

push

const User = {
    //使用props获取路由参数
    props: ['id'],
    //通过 $route.params 获取参数
    template: `
    <div>
        <div>User {{id}} 组件</div>
        <button @click='goRegister'>跳转到注册界面</button>
    </div>`,
    methods: {
        goRegister(){
            //跳转指定页面
            this.$router.push('/register')
        }
    }
}

go

var Register = {
    template:  `
    <div>
        <h1>Register 组件</h1>
        <hr/>
        <button @click='goBack'>回退一步</button>
        <router-link to="/register/tab1">Tab1</router-link>
        <router-link to="/register/tab2">Tab2</router-link>

        <!-- 子路由填充位 -->
        <router-view></router-view>
    </div>`,
    methods:{
        goBack(){
            //回退一步
            this.$router.go(-1);
        }
    }
}

push方法参数

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

推荐阅读更多精彩内容