vue

vue-router之间的操作

2019-09-26  本文已影响0人  非_MO

既然用了vue,那么vue-router就是在项目开发中必不可少的一部分操作了,这里我特意整理了一些在vue项目开发过程中涉及到的一些操作吧。

路由之间传参

由A路由到B路由之间的传参,可以通过$router的query和param传递,用query传递的参数,会在浏览器的url路径中展示出来,不具有保密性,但是刷新后依旧存在,由param传递的参数,不会在浏览器的url路径中展示出来,而且刷新后不会再在当前页面中展示,具体使用方法如下:

this.$router.push({
    path: "/imp/style",
    query:"params"
})
this.$router.push({
    path: "/imp/style",
    query:{key:value}
})
this.$router.push({
    path: "/imp/style",
    param:{key:value}
})
this.$router.push({
    path: "/imp/style",
    param:"params"
})

取值方法:

query:
this.$route.query
param:
this.$route.param

父子组件之间传参

父组件

先在父组件中引入子组件,

import childToP from './childToP'

然后在tempate里面使用

<div class="context">
        <div>这是父组件
            <p>{{message}}</p></div>
        <childToP @childData="getData"></childToP>
</div>

定义一个@childData="getData"方法,接收子组件传递给父组件的事件,@childData这个方法是子组件里定义的,如果自组建立未定义,那在父组件里可以不用接收。

 methods: {
            getData(getVal) {
                  // getVal就是子组件的操作事件传过来的值
                this.message = getVal;
            },
        },
父组件向子组件传参

如果需要从父组件里向子组件传递信息或者点击事件,可以在使用子组件的时候,在子组件上绑定属性和要传递的事件,要先在data里面声明该属性,即:pdata,然后在子组件里面使用props来接收,

import toC from './toC'
<to-C :msgFromP="pdata" :aaa="func"></to-C>
<template>
    <div class="context">
        this is aaa
        <to-C :msgFromP="pdata" :aaa="func"></to-C>
    </div>
</template>
<script>
    import toC from './toC'
 
    export default {
        components: {toC},
        name: "parentToC",
        data() {
            return {
                pdata: 'this is parent message'
            }
        },
        methods: {
            //这里是在父组件定义的方法,在子组件里面也可以接收,然后通过对子组件的操作实现你的目的
            func() {
                console.log('ccc');  
            }
        }
    }
</script>

在子组件里面接收

<template>
    <div class="context222">
        <p class="text" @click="aaa">{{msgFromP}}</p>
    </div>
</template>
<script>
    export default {
        name: "toC",
        props: {
            msgFromP: '',
            aaa: null
        }
    }
子组件

在子组件中,可以直接在div里写你要传递的信息,不需要使用 this.$emit() 方法也可;

<template>
    <div class="context">
        <div>{{msg1}}</div>
    </div>
</template>
<script>
    export default {
        name: "childToP",
        data() {
            return {
                msg1:'这是子组件这是子组件这是子组件',
             
            }
        }
    }
</script>
子组件向父组件传参

如果你需要操作父组件里面的数据或者给父组件发信息,先定义一个点击事件,然后用
this.$emit("childData", this.msg) 方法,把子组件里要传递的信息发送过去即可。

<template>
  <div class="context">
      <div @click="tomsg">这是子组件</div>
  </div>
</template>
<script>
    export default {
      name: "childToP",
      data(){
        return{
          msg:"this is child data"
        }
      },
      methods:{
        tomsg(){
            // 这里也可以是对象
            let data="这是子组件里面的数据"
            this.msg=data
            this.$emit("childData",this.msg)
        }
      }
    }
</script>
上一篇下一篇

猜你喜欢

热点阅读