>웹 프론트엔드 >프런트엔드 Q&A >vuejs에서 경로 점프 및 값 전달을 구현하는 방법

vuejs에서 경로 점프 및 값 전달을 구현하는 방법

青灯夜游
青灯夜游원래의
2021-10-26 14:51:442498검색

Vuejs 경로 점프 값 전송 방법: 1. "7c87333a3ceb3b82d97d1b332587be67" 문을 사용하여 전송 값으로 점프합니다. 2. "this.$router.push({ path :'/ user'})" 문을 사용하여 값을 전달하도록 점프합니다.

vuejs에서 경로 점프 및 값 전달을 구현하는 방법

이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.

vue에는 다양한 유형의 경로 점프 매개변수가 있습니다. 제가 일반적으로 사용하는 매개변수는 다음과 같습니다

  • Jump through router-link

  • Route jump through programmatic Navigation

1. router-linkrouter-link

<router-link 
 :to="{
  path: &#39;yourPath&#39;, 
  params: { 
   name: &#39;name&#39;, 
   dataObj: data
  },
  query: {
   name: &#39;name&#39;, 
   dataObj: data
  }
 }">
</router-link>

 1. path -> 是要跳转的路由路径,也可以是路由文件里面配置的 name 值,两者都可以进行路由导航
 2. params -> 是要传送的参数,参数可以直接key:value形式传递
 3. query -> 是通过 url 来传递参数的同样是key:value形式传递

 // 2,3两点皆可传递

2、$router

// 组件 a
<template>
 <button @click="sendParams">传递</button>
</template>
<script>
 export default {
 name: &#39;&#39;,
 data () {
  return {
  msg: &#39;test message&#39;
  }
 },
 methods: {
  sendParams () {
  this.$router.push({
   path: &#39;yourPath&#39;, 
   name: &#39;要跳转的路径的 name,在 router 文件夹下的 index.js 文件内找&#39;,
   params: { 
    name: &#39;name&#39;, 
    dataObj: this.msg
   }
   /*query: {
    name: &#39;name&#39;, 
    dataObj: this.msg
   }*/
  })
  }
 },
 computed: {

 },
 mounted () {

 }
 }
</script>
<style scoped></style>
----------------------------------------
// 组件b
<template>
 <h3>msg</h3>
</template>
<script>
 export default {
 name: &#39;&#39;,
 data () {
  return {
  msg: &#39;&#39;
  }
 },
 methods: {
  getParams () {
  // 取到路由带过来的参数 
  let routerParams = this.$route.params.dataobj
  // 将数据放在当前组件的数据内
  this.msg = routerParams
  }
 },
 watch: {
 // 监测路由变化,只要变化了就调用获取路由参数方法将数据存储本组件即可
  &#39;$route&#39;: &#39;getParams&#39;
 }
 }
</script>
<style scoped></style>

2, $router 점프 방법rrreee

관련 추천: "🎜vue.js tutorial🎜"🎜

위 내용은 vuejs에서 경로 점프 및 값 전달을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.