如何将属性传递给Vue Js中由路由器调用的组件

时间:2017-09-11 19:58:44

标签: javascript vue.js vuejs2 vue-component vue-router

我是VueJs的新手,我有两个组件的问题。我试图用vuejs路由器显示一个组件,我必须将属性传递给该组件,因为它不是该组件的子组件(它在不同的目录中),我如何将数据传递给该组件? 例如:

这是一个父组件:

 <template>
    <div class="container">
       <router-link to="/Form"></router-link>
    </div>
</template> 
<script>
  export default{
  data(){
    return{
      values: {val1: 123, val2: 321}
    }
  }
}
</script>

这是一个需要属性的组件,Form组件:

 <template>
    <div class="container">
       <form>
         <input type="text" v-model="values.val1"/>
         <input type="number" v-model="values.val2"/>
       </form>
    </div>
</template> 
<script>
  export default{
  props: {
    values: {
      type: Object
    }
  }
}
</script>

1 个答案:

答案 0 :(得分:1)

您可以将值作为query对象传递:

<router-link :to="{ path: '/Form', query: values }"></router-link>

让Form组件检查$route.query值,而不是使用props

<template>
  <div class="container">
    <form>
      <input type="text" v-model="values.val1"/>
      <input type="number" v-model="values.val2"/>
    </form>
  </div>
</template> 
<script>
export default {
  data() {
    return {
      values: this.$route.query
    }
  }        
}
</script>

请注意,这些值将作为查询字符串添加到URL中。

否则,我会看一下this post。或者可以查看Vuex