首页 > 其他分享 >07-vue-router的使用

07-vue-router的使用

时间:2024-05-06 21:13:34浏览次数:18  
标签:vue 07 next path router 路由 name

vue-router使用

// npm导入
npm install vue-router --save

// cnpm淘宝镜像导入
cnpm install vue-router --save
// 如果没有安装淘宝镜像需要先安装
npm install -g cnpm --registry=https://registry.npm.taobao.org

直接跳转:this.$router

如果获取参数,需要使用this.$route

通过router发送数据带参数

方式1

// 发送
this.$router.push("/?name=小满") // 函数中
$router.push("/?name=小满") //视图中直接使用

// 获取参数
console.log(this.$route.query); // 对象

方式2

// 发送
// 函数中
this.$router.push({
    name: "home",
    query: {name: "小满", age: 3, hobby: "逃课"}
})

// 视图中
// 函数中,这种就不要再视图中使用了,太难看了
router.push({
    name: "home",
    query: {name: "小满", age: 3, hobby: "逃课"}
})

// 获取一样
console.log(this.$route.query); // 对象 {name: '小满', age: 3, hobby: '逃课'}

通过router-link发送数据带参数

方式1

// 发送
<router-link :to="{path: '/?name=阿珂&age=4'}">
    <button>回首页</button>
</router-link>

// 获取
console.log(this.$route.query); // {name: '阿珂', age: '4'}

方式2

// 发送
<router-link :to="{path: '/', query:{name: '阿珂', age:4, hobby: '抢人头'}}">
    <button>回首页</button>
</router-link>

// 获取
console.log(this.$route.query); // {name: '阿珂', age: '4', hobby: '抢人头'}

方式3

// router/index.js
{
    path: '/:name/:age/:hobby',
    name: 'home',
    component: HomeView
  }

// 发送
<router-link :to="{name: 'home', params:{name: '阿珂', age:4, hobby: '抢人头'}}">
    <button>回首页</button>
</router-link>

// 获取
console.log(this.$route.params); //{name: '阿珂', age: 4, hobby: '抢人头'}

相关api

1 指的是:this.$router--->方法
2 常用的
this.$router.push(path): 相当于点击路由链接(可以返回到当前路由界面)
this.$router.replace(path): 用新路由替换当前路由(不可以返回到当前路由界面)
this.$router.back(): 请求(返回)上一个记录路由
this.$router.go(-1): 请求(返回)上一个记录路由
this.$router.go(1): 请求下一个记录路由

多级路由

  1. 在components下面建立对应的子组件
StoreView.vue
FishView
  1. 在router/index.js中
    1. 需要多级路由的视图组件下面,新建一个children,对应一个数组,数组的内部写上path,以及component。
    2. children内的path不需要添加斜杠。
// 导入
import StoreView from "@/components/StoreView.vue"
import FishView from "@/components/FishView.vue"

// 写多级路由
{
    path: '/',
    name: 'home',
    component: HomeView,
    children:[
      {
        path: 'store', 
        component: StoreView,
      },
      {
        path: 'fish',
        component: FishView,
      }
    ]
}
  1. 组件中使用
<!-- template -->
<div class="content">
    <div class="left">
        <!-- 这里写路径,直接拼就可以了 -->
        <router-link to="/store"><p>峡谷商店</p></router-link>
        <router-link to="/fish"><p>摸鱼技巧</p></router-link>
    </div>
    <div class="right">
        <!-- 这里不需要写别的 -->
        <router-view></router-view>
    </div>
</div>

别忘记注册组件到components中

import StoreView from "@/components/StoreView.vue"
import FishView from "@/components/FishView.vue"

components: {
    StoreView,
	FishView
}

img

路由守卫

在路由守卫中,to 参数代表即将要进入的目标路由对象,from 参数代表当前导航正要离开的路由对象,next 参数是一个函数,用于确保导航成功完成。

通过to.path,可以获取到目标路由的路径,通过from.path可以获取到离开的路由地址,比如从登录跳转到首页,那么to.path就是/homefrom.path就是/login

一般定义在router/index.js下面,export default router之前。

const router = new VueRouter({
  routes: [...], // 定义路由规则
});

router.beforeEach((to, from, next) => {
  // 在导航触发时调用
  // 可以进行一些逻辑操作,例如权限验证
  next(); // 必须调用该方法来确保导航成功完成
});

router.afterEach((to, from) => {
  // 在导航完成时调用
  // 可以进行一些清理操作
});

export default router

案例,需要登录后才能正常进入到指定页面,注意这里使用next()完成重定向即可,不需要使用this.$router.push()

router.beforeEach((to, from, next) => {
    // 如果要取的目标是登录页面,那就让他去吧
  if (to.path === '/login'){
    return next()
  }
  // 获取token
  let token = window.localStorage.getItem('token')
  if (!token){
      // 如果没有携带token,那就让他去登录吧
    return next('/login') 
  }
  // 包含token正常跳转
  next()
})

路由的两种工作模式

路由的两种工作模式是"hash"模式和"history"模式。它们的主要区别在于URL的表现形式和对浏览器历史记录的影响。

  • Hash 模式

    • 在 hash 模式下,URL 中会带有 # 符号,例如:http://www.example.com/#/home
    • 这种模式不会向服务器发送请求,因为 # 后面的内容被认为是页面内的锚点。
    • 可以兼容更多的浏览器,但在 SEO 优化方面可能存在一些问题。
  • History 模式

    • 在 history 模式下,URL 是正常的路径形式,例如:http://www.example.com/home
    • 这种模式会向服务器发送请求,需要后端配置支持,以避免在刷新页面或直接访问 URL 时出现 404 错误。
    • 可以更加友好地展示 URL,但需要后端配合。
const router = new VueRouter({
  mode: 'history', // 这里设置 history 或者 hash
  base: process.env.BASE_URL,
  routes
})

标签:vue,07,next,path,router,路由,name
From: https://www.cnblogs.com/ccsvip/p/18175947

相关文章

  • 08-初始vue3
    写在前面https://juejin.cn/post/7106374777601785893https://juejin.cn/post/7253828299938906169配置项写法<body><divid="app"></div></body><script>constapp=Vue.createApp({//...})app.mo......
  • vue3
    【介绍】#vue3的变化1.性能的提升-打包大小减少41%-初次渲染快55%,更新渲染快133%-内存减少54%2.源码的升级使用Proxy代替defineProperty实现响应式重写虚拟DOM的实现和Tree-Shaking3.拥抱TypeScriptV......
  • 07. C语言程序执行流程控制
    【有条件执行语句】ifesle语句ifelse语句根据一个条件确定是否执行一段代码,执行条件是一个布尔值,布尔值为true则执行,为false则不执行,同时可以设置不符合条件时执行的语句。if(执行条件){  符合条件时执行的代码;}else{  不符合条件时执行的代码;}使用事项:1......
  • vue怎么设置html不缓存 但是js、css等文件做缓存
    在 Vue.js 项目中,我们通常使用 webpack 打包工具进行编译构建,其中 HTML 文件通常不做缓存,而 JS、CSS 文件需要做缓存。这可以通过 webpack 的配置实现。下面是针对你的问题的步骤:1. 打开 webpack 的配置文件 webpack.config.js 或者 webpack.prod.config.js(如果你......
  • 工程化之创建vue项目
    工程化之创建vue项目清空缓存npmcacheclean--force搭建vue2的环境装cnpm这个包,cnpm替代npmnpminstall-gcnpm--registry=https://registry.npmmirror.com安装vue脚手架cnpminstall-g@vue/cli通过vue命令创建vue项目vuecreatemyfirstvue步骤:......
  • vue ref
    ref1vue2ref属性也可以实现组件间通信:子和父都可以实现通信ref放在标签上,拿到的是原生的DOM节点ref放在组件上,拿到的是组件对象,对象中的数据、函数都可以直接使用通过这种方式实现子传父(this.$refs.mychild.text)通过这种方式实现父传子(调用子组件方法传参数)......
  • vue 组件通信
    组件通信1.父传子在全局组件中自定义属性:<Child:myname="qname"></Child>在组件中获取:{{myname}}<divid="app"><h1>组件使用-父传子-自定义属性</h1><Child:myname="qname"></Child></div><script>......
  • vue 生命周期钩子
    生命周期钩子函数描述beforeCreate创建Vue实例之前调用created创建Vue实例成功后调用(可以在此处发送异步请求后端数据)beforeMount渲染DOM之前调用mounted渲染DOM之后调用,这时候可以向后端发送数据了beforeUpdate重新渲染之前调用(数据更新等操作时,控制D......
  • vue 指令
    指令v-text标签内容显示js变量对应的值<divid="box"><spanv-text="a"></span><!--等同于-->{{a}}</div><script>letvm=newVue({el:'#box',data:{a:......
  • vue 计算属性
    计算属性在Vue2中使用computed在Vue2中,计算属性是通过computed选项来定义的。示例中,我们定义了一个fullName计算属性,它会根据firstName和lastName的值计算出完整的姓名。exportdefault{data(){return{firstName:'John',lastName:'......