天天看点

a标签传值到另一个页面_vue组件之间的传值vue同级组件间传值

a标签传值到另一个页面_vue组件之间的传值vue同级组件间传值

把一个页面里的东西引入到另一个页面,就是父子组件了啊,有一些公共的可以提取的就封装成组件,相互之间有数据传递就是组件传值

父组件向子组件传值

第一个就是要明白怎么在父页面中向子组件中传值?你可以给子组件传入一个静态的值:

但我们一般都是需要传动态的值,所以需要

v-bind

绑定,当然,你传的值可以是数字、对象、数组等等,

动态赋一个变量的值post.author.name”>
           

第二个就是要知道如何在子组件中接受父页面传过来的值,有几点需要了解:

1.组件实例的作用域是孤立的。

2.组件要显式的用props选项声明它预期的数据,如:

// 某个子组件中:export default {  props: {    title: {      type: String,      default: 'hello world'    }  }}
           

子组件向父组件传值

基本概念

在vue中,父子组件的关系可以总结为prop向下传递,事件向上传递。父组件通过prop给子组件下发数据,子组件通过事件给父组件发送信息。

a标签传值到另一个页面_vue组件之间的传值vue同级组件间传值

每个Vue实例都实现了事件接口:使用$on(evntName)监听事件;使用$emit(eventName,optionalPayload)触发事件。另外,父组件可以在使用子组件的地方直接

用v-on来监听子组件触发的事件。

举例说明

  • 父组件在组件上定义了一个自定义事件childFn,事件名为parentFn用于接受子组件传过来的message值。
<template>    <div class="test">      <test-com @childFn="parentFn">test-com>      <br/>       子组件传来的值 : {{message}}    div>template><script>export default {    // ...    data: {        message: ''    },    methods: {       parentFn(payload) {        this.message = payload;      }    }}script>
           

子组件是一个buttton按钮,并为其添加了一个click事件,当点击的时候使用$emit()触发事件,把message传给父组件。

<template> <div class="testCom">    <input type="text" v-model="message" />    <button @click="click">Sendbutton>div>template><script>export default {    // ...    data() {        return {          // 默认          message: '我是来自子组件的消息'        }    },    methods: {      click() {            this.$emit('childFn', this.message);        }    }    }script>
           

vue同级组件间传值

1、在main.js同级目录下新建new.js文件

import Vue from 'vue'export default new Vue()
           

2、在组件a中传出值

先引入new.js文件,再通过$emit传值

<template>  <div @click="onfocus">div>template><script>    import New from '@/new.js'      export default{    methods:{        onfocus:function(fromid){          New.$emit('getisshow',{            show:true          })         }      }  }script>
           

3、在同级b组件中通过$on接收

继续阅读