首页 > 其他分享 >Vue之 vue-router

Vue之 vue-router

时间:2023-04-14 18:26:01浏览次数:60  
标签:index Vue name vue 跳转 router path 路由

目录

简介

vue-router是Vue.js官方的路由插件,它和vue.js是深度集成的,适合用于构建单页面应用。
vue-router是基于路由和组件的,路由用户设定访问路径的,将路径和组件映射起来。在vue-router的单页面应用中,页面的路径的改变就是组件的切换。
官网地址:https://router.vuejs.org/zh/

安装vue-router

# 可以在创建项目时就直接安装好vue-router
# 也可以单独安装,使用下面的命令
npm install vue-router

# 第二步:在main.js中引入
import router from './router'
new Vue({
  router,    # 添加这一行
  store,
  render: h => h(App)
}).$mount('#app')

使用vue-router

配置路由的跳转,只需要在src/router/index.js目录下导入组件之后,再

import IndexView from "@/views/IndexView";   // 创建好组件之后,导入组件
const routes = [
    {
        path: '/index/',       // 浏览器的路由
        name: 'index',         // 别名
        component: IndexView   // 对应的是哪个组件
    },
]

router的方法

this.$router.push(path)    // 相当于点击路由链接(可以返回到当前路由界面)
this.$router.replace(path) // 用新路由替换当前路由(不可以返回到当前路由界面)
this.$router.back()        // 请求(返回)上一个记录路由
this.$router.go(-1)        // 请求(返回)上一个记录路由
this.$router.go(1)         // 请求下一个记录路由
this.$router.forward()     // 前进

路由跳转

方法一 使用js控制

  • 使用给按钮绑定事件的方式进行跳转
<button @click="goToLogin">点我</button>
<script>
export default {
  name: 'HomeView',
  methods:{
    goToLogin(){
      this.$router.push('/Index')   // 这样点击上面的按钮后就会跳转到index页面了
    }
  }
}
</script>

方法二 使用标签控制

  • 使用标签的方法进行跳转
<!--写法-->
<router-link to="路由"> xxx </router-link>
<!--示例-->
<router-link to="/index"><button>点我</button></router-link>

路由跳转携带参数

方法一 使用问号携带

<router-link to="/index/?pk=1"><button>点我</button></router-link>
或
<router-link to="/index/?pk="+{{xxx}}><button>点我</button></router-link>
  • 通过打印console.log(this.$route)发现,数据在query中
    image
  • 所以如果要取数据,可以直接使用query对象取
<script>
export default {
  name: "IndexView",
  created() {
    console.log('route:', this.$route.query.pk)
  }
}
</script>

方法二 使用斜杠分隔符携带

  • 第一步 配置router目录下index.js
{
    path: '/index/:pk',    // 这里配置什么参数,前台传入的值对应的Key就是什么
    name: 'index',
    component: IndexView
},
  • 第二步 配置跳转功能
<router-link to="/index/1/"><button>点我</button></router-link>
  • 第三步取值
    根据console.log(this.$route)可以看到,值在params中
    image
console.log(this.$route.params.pk)   // 这样就可以取到值了

方法三 使用对象的方式跳转

  • 可以直接在push方法中携带参数
<template>
  <div class="home">
    <button @click="clickFunc">点我</button>
  </div>
</template>

<script>
export default {
  name: 'HomeView',
  methods:{
    clickFunc(){
      this.$router.push({
        name: 'index',        // 这里的name就是router/index.js中路由配置的name别名,这个路由不需要作变化
        query:{               // 可以将内容放到query中
          name: 'jack',
          age: '18'
        },
        params:{              // 可以将内容放到params中,这样路由中需要配置为path: '/index/:pk'
          pk: '16',
        }
      })
    }
  }
}
</script>
  • 可以看到,使用问题携带参数的截图
    image

  • 可以看到,使用斜杠分隔携带参数的截图
    image

方法四 标签方式跳转携带参数

{
path: '/index/:pk',    // 这里配置了:pk
    name: 'index',
        component: IndexView
},
<template>
  <div class="home">
    <!--可以定义好对象,将内容写到对象中,并在这里引用-->
    <router-link :to="obj">
      <button>点我</button>
    </router-link>
    <!--可以将跳转对象写到标签中-->
    <!--如果路由配置了:pk这种分隔的方式,可以写query和params两个-->
    <router-link :to="{name:'index', query:{id:99}, params:{pk:100}}">
      <button>点我2</button>
    </router-link>
  </div>
</template>

<script>
export default {
  name: 'HomeView',
  data() {
    return {
      obj: {
        name: 'index',
        query: {id: '99'},
        params: {pk: '100'}
      }
    }
  }
}
</script>
  • 返回结果如下显示
    image

router与route的区别

route     # 当前页面的对象,也可以说是当前路由对象
router    # new VueRouter对象,也是就是vue-router的实例
  • 我们可以使用console.log查看一下这两个对象分别是什么
    image
  • 可以看到route对应的就是当前页面的一些信息
  • router中对应的就是vue-router实例

多级路由

routes:[
    {
        path: '/about',
        component: About,
    },
    {
        path: '/home',
        component: Home,
        children: [ //通过children配置子级路由
            {
                path: 'news', //此处一定不要写:/news 注意这个斜杠
                component: News
            },
            {
                path: 'message',//此处一定不要写:/message 注意这个斜杠
                component: Message
            }
        ]
    }
]

// 跳转
< router - link
to = "/home/news" > News < /router-link>
    {
        path: '/demo',
        component: Demo,
        children: [
            {
                path: 'test',
                component: Test,
                children: [
                    {
                        name: 'hello'     // 给路由定义别名
                        path: 'welcome',
                        component: Hello,
                    }
                ]
            }
        ]
    }
<!--简化前,需要写完整的路径 -->
<router-link to="/demo/test/welcome">跳转</router-link>

<!--简化后,直接通过别名跳转 -->
<router-link :to="{name:'hello'}">跳转</router-link>

<!--简化写法配合传递参数 -->
<router-link :to="{name:'hello',query:{id:666,itle:'你好'}}">跳转</router-link>

路由守卫

对路由进行权限控制,按分类分为:全局守卫(最常用),独享守卫,组件内守卫

全局路由守卫

  • 前置路由守卫:在进路由前,执行代码。
  • 后置路由守卫:路由跳转走,执行代码。

前置路由守卫配置

  • 只需要在router/index.js文件中新增一个函数即可
router.beforeEach(
    (to, from, next) => {
        console.log(to, from, next)
        // to 代表要去的路由
        // from 代表从哪个路由跳转过来
        // next 是一个函数,需要加括号执行,没有next则不会跳转到要去的路由

        // 下面写一个简单的路由守卫功能
        if (to.name == 'index'){
            console.log('成功访问index界面')
            next()  // 这里不加next()是不会跳转的
        }else{
            alert('您不允许访问这个页面')
        }
    }
)
  • 访问index页面可以访问
    image

  • 访问home页面无法访问,先是弹窗,之后因为没有next()所以也不会跳转到home路由中
    image

后置路由守卫配置

  • 与前置不同的只是函数名不同,用得很少
router.afterEach((to, from)=> {
函数内容
})

独享守卫

// 该文件专门用于创建整个应用的路由器
import VueRouter from 'vue-router'
//引入组件
import About from '../pages/About'
import Home from '../pages/Home'
import News from '../pages/News'
import Message from '../pages/Message'
import Detail from '../pages/Detail'

//创建并暴露一个路由器
const router =  new VueRouter({
    routes:[
        {
            name:'guanyu',
            path:'/about',
            component:About,
            meta:{title:'关于'}
        },
        {
            name:'zhuye',
            path:'/home',
            component:Home,
            meta:{title:'主页'},
            children:[
                {
                    name:'xinwen',
                    path:'news',
                    component:News,
                    meta:{isAuth:true,title:'新闻'},
                    beforeEnter: (to, from, next) => {
                        console.log('独享路由守卫',to,from)
                        if(to.meta.isAuth){ //判断是否需要鉴权
                            if(localStorage.getItem('name')==='lqz'){
                                next()
                            }else{
                                alert('名不对,无权限查看!')
                            }
                        }else{
                            next()
                        }
                    }
                },
                {
                    name:'xiaoxi',
                    path:'message',
                    component:Message,
                    meta:{isAuth:true,title:'消息'},
                    children:[
                        {
                            name:'xiangqing',
                            path:'detail',
                            component:Detail,
                            meta:{isAuth:true,title:'详情'},
                        }
                    ]
                }
            ]
        }
    ]
})

export default router

组件内守卫

//进入守卫:通过路由规则,进入该组件时被调用
beforeRouteEnter (to, from, next) {
},
//离开守卫:通过路由规则,离开该组件时被调用
beforeRouteLeave (to, from, next) {
}

//通过路由规则,进入该组件时被调用
    beforeRouteEnter (to, from, next) {
        console.log('About--beforeRouteEnter',to,from)
        if(to.meta.isAuth){ //判断是否需要鉴权
            if(localStorage.getItem('school')==='atguigu'){
                next()
            }else{
                alert('学校名不对,无权限查看!')
            }
        }else{
            next()
        }
    },

    //通过路由规则,离开该组件时被调用
    beforeRouteLeave (to, from, next) {
        console.log('About--beforeRouteLeave',to,from)
        next()
    }

标签:index,Vue,name,vue,跳转,router,path,路由
From: https://www.cnblogs.com/smyz/p/17318299.html

相关文章

  • vue路由传值总结
    路由传值总结1.路由导航:在router.js中配置路由的path为/XXX/:id的方式,在路由跳转的时候,设置路径/XXX/123即可跳转接收通过this.$route.params.id 即可拿到1232.params传参:通过this.$router.push传参,配置name匹配路由name属性,设置params对象,内部为传入......
  • vue中使用jsx
    前言相对来说有些时候用jsx更合适,更灵活些安装依赖有对应的包支持yarnadd--dev@vitejs/plugin-vue-jsx配置插件在vite.config.jsimport{defineConfig}from"vite";importvuefrom"@vitejs/plugin-vue";importvueJsxfrom"@vitejs/plugin-vue-jsx";//ht......
  • vue列表渲染之for循环
    vue列表渲染之for循环前端开发中,如果涉及列表渲染,都会提示或要求每个列表项使用唯一的key,那很多开发者就会直接使用数组的index作为key的值,而并不知道key的原理。那么以下会讲解key的作用以及为什么最好不要使用index作为key的属性值。1、作用在虚拟DOM中,key是虚......
  • vue通过Export2Excel.js进行导入excel,获取数据
    <!--封装的模板下载和导入按钮和功能组件--><template><spanstyle="margin-left:10px"><el-buttonsize="mini"class="el-icon-download"@click="downFiles">下载模板</el-button><el-upload......
  • Vue2总结
    笔记脚手架文件结构├──node_modules├──public│├──favicon.ico:页签图标│└──index.html:主页面├──src│├──assets:存放静态资源││└──logo.png││──component:存放组件││└──HelloWorld.vue│......
  • 2023-04-14 vue之组件全局注册
    新建一个vue文件,随便写点什么,然后在main.js中引入,如下:xxx.vue:<template><viewclass="container"><viewclass="content">登录窗口</view></view></template><script>exportde......
  • Vue3 Vite H5 手写一个横向展开的多级树列表
    最近写h5要做那种稍微复杂一点的树,没找到现成的UI组件库可用,vant的树只有两级不满足,只能自己写ps.选框的选择/反选/半选对父子选项的影响还有bug,留到脑子好的时候再优化效果代码框架是Vue3+Vite+Vant4。复选框用的vant的checkbox,应该也可以换别的或者原生。模板<templ......
  • vue 使用 vue-seamless-scroll 实现LED屏滚动效果
    yarnaddvue-seamless-scroll<divclass="index-roll"><vue-seamless-scroll:data="partnerList":class-option="optionLeft"><ul><liv-for=&quo......
  • vue3微信公众号商城项目实战系列(3)项目初始文件及文件夹简介
    首先我们来看下项目的文件结构图,如下: 各个文件及文件夹作用如下:文件或文件夹名称作用.vscodeVisualStudioCode开发工具的配置信息存放目录,从这个目录可以看出vue3确实是推荐使用vscode作为开发工具的。node_modules项目中用到的包存放目录,当我们用"npminstall......
  • vue3 + ts + electron项目搭建过程
    1、输入指令npmcreateelectron-vite2、工程创建好后进入工程目录 执行npmi加载依赖项,加载过程中可能会出现加载失败的问题,是因为github资源的问题,非项目本身问题,多执行几次即可3、打包输入npmrunbuild,打包过程也会出现打包失败的问题,原因和上面一样,也是github资......