Vue2(路由)(一)

简介: Vue2(路由)

一,路由原理(hash)


单页应用的路由模式有两种

1、哈希模式(利用hashchange 事件监听 url的hash 的改变)
2、history模式(使用此模式需要后台配合把接口都打到我们打包后的index.html上)


hash模式的原理:

核心是锚点值的改变,我们监听到锚点值改变了就去局部改变页面数据,不做跳转。跟传统开发模式url改变
后立刻发起请求,响应整个页面,渲染整个页面比路由的跳转用户体验更好


二,路由安装和使用(vue2)


导入路由插件

<script src="../js/vue-router.js"></script>


安装路由插件到Vue中

Vue.use(VueRouter);


创建VueRouter对象

    // 路由的安装 前提是要导入路由js
    Vue.use(VueRouter)
    // 创建一个登录子组件
    var login = {
        template:`
            <div>
                登录页面    
            </div>
        `,
    }
    // 创建路由配置实例,主要实现,路劲和子组件之间的映射
    var myrouter = new VueRouter({
        routes:[
            {path:'/login/id',name:'login',component:login},
        ]
    })


使用路由

<body>
    <div id="app">
        头部
        <!-- 下面是路由出口 -->
        <router-view></router-view>
        尾部
    </div>
</body>
<script src="../Vue2/js/vue2.7.js"></script>
<script src="../Vue2/js/vue-router.js"></script>
<script>
    // 路由的安装 前提是要导入路由js
    Vue.use(VueRouter)
    // 创建一个登录子组件
    var login = {
        template:`
            <div>
                个人页面    
            </div>
        `,
    }
    // 创建路由配置实例,主要实现,路劲和子组件之间的映射
    var myrouter = new VueRouter({
        routes:[
            {path:'/login',name:'login',component:login},
        ]
    })
    var app = new Vue({
        el:'#app',
        data(){
            return{
            }
        },
        router:myrouter,
    })
</script>


三,路由跳转


路由的跳转有两种方式:


使用标签

<router-link to="/login">登录</router-link>


编程式路由,使用js

this.$router.push({path:'/login'});
this.$router.replace({path:'/login'});


说明:

1.this.$router.push(); 会向history中添加记录

2.this.$router.replace();不会向history中添加记录。

3.this.$router.go(-1)常用来做返回上一个地址。


路由中的对象:

1.this.$route 路由信息对象,只读。

2.this.$router 路由操作对象,只写。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="app">
        头部
        <router-link to="/login">登录</router-link>
        <router-link to="/person">个人</router-link>
        <button @click="toxiaohao">api 王导</button>
        <!-- 下面是路由出口 -->
        <router-view></router-view>
        尾部
    </div>
</body>
<script src="../Vue2/js/vue2.7.js"></script>
<script src="../Vue2/js/vue-router.js"></script>
<script>
    // 路由的安装 前提是要导入路由js
    Vue.use(VueRouter)
    // 创建一个登录子组件
    var login = {
        template:`
            <div>
                登录页面     
            </div>
        `,
    }
     // 创建一个登录子组件
     var person = {
        template:`
            <div> 
                个人页面 
            </div>
        `,
    }
    // 创建一个个人页面子组件
    var xiaohao = {
        template:`
            <div>
                王导页面    
            </div>
        `,
    }
    // 创建路由配置实例,主要实现,路劲和子组件之间的映射
    var myrouter = new VueRouter({
        routes:[
            {path:'/login',name:'login',component:login},
            {path:'/person',name:'person',component:person},
            {path:'/xiaohao',name:'xiaohao',component:xiaohao}
        ]
    })
    var app = new Vue({
        el:'#app',
        data(){
            return{
            }
        },
        router:myrouter,
        methods:{
            toxiaohao(){
                this.$router.replace({
                    path:'/xiaohao'
                })
            },
        }
    })
</script>
</html>

相关文章
|
3月前
|
资源调度 JavaScript 前端开发
路由管理:Vue Router的使用和配置技巧
【10月更文挑战第21天】路由管理:Vue Router的使用和配置技巧
60 3
|
3月前
|
JavaScript API
vue 批量自动引入并注册组件或路由等等
【10月更文挑战第12天】 vue 批量自动引入并注册组件或路由等等
|
3月前
|
JavaScript 前端开发 API
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
vue3中常用插件的使用方法:按需引入自定义组件,自动导入依赖包,自动生成路由,自动生成模拟数据
1002 0
|
3月前
|
JavaScript 前端开发 UED
vue中vue-router路由懒加载(按需加载)的作用以及常见的实现方法
vue中vue-router路由懒加载(按需加载)的作用以及常见的实现方法
245 1
|
4月前
|
JavaScript
vue项目中使用vue-router进行路由配置及嵌套多级路由
该文章详细说明了如何在Vue项目中配置和使用vue-router进行单页面应用的路由管理,包括设置嵌套路由和实现多级路由导航的示例。
|
3月前
|
JavaScript 前端开发 UED
|
3月前
|
JavaScript 前端开发 API
前端技术分享:Vue.js 动态路由与守卫
【10月更文挑战第1天】前端技术分享:Vue.js 动态路由与守卫
|
3月前
|
资源调度 JavaScript UED
如何使用Vue.js实现单页应用的路由功能
【10月更文挑战第1天】如何使用Vue.js实现单页应用的路由功能
|
3月前
|
JavaScript 前端开发
vue尚品汇商城项目-day01【4.完成非路由组件Header与Footer业务】
vue尚品汇商城项目-day01【4.完成非路由组件Header与Footer业务】
47 2
|
3月前
|
JavaScript 前端开发
vue尚品汇商城项目-day01【3.项目路由的分析】
vue尚品汇商城项目-day01【3.项目路由的分析】
37 1