IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue组件传值方式 -> 正文阅读

[JavaScript知识库]vue组件传值方式

父组件向子组件传值:

父组件

<template>
    <div id="app">
        <img alt="Vue logo" src="./assets/logo.png" />
        <HelloWorld msg="Welcome to Your Vue.js App" :msg2="msg2" /> <!-- 3.在template写上子组件,msg就是向子组件传的值,也可以用v-bind动态绑定 -->
        
    </div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";  // 1.引入子组件

export default {
    name: "App",
    components: {
        HelloWorld,  // 2.注册子组件
    },
    data() {
        return {
            msg2: '动态的值'
        }
    },
};
</script>

子组件

<template>
    <div class="hello">
        msg的值=>{{msg}}
        <p>msg2的值=>{{msg2}}</p>
    </div>
</template>

<script>
export default {
    name: 'HelloWorld',
    props: ['msg', 'msg2']   // 4.在子组件中写上porps接收父组件的传过来的参数,可以直接写到template使用,或做其他操作
}
</script>

效果
在这里插入图片描述

子组件向父组件传值:

子组件

<template>
    <div class="hello">
        <button @click="doSend">点击</button>
        <!-- 1.绑定一个事件触发向父组件传值,也可以是其他事件或其他操作 -->
    </div>
</template>

<script>
export default {
    name: 'HelloWorld',
    data() {
        return {
            sonData: '子组件中定义的值'
        }
    },
    methods: {
        doSend() {
            const that = this;
            // 2.在点击触发的时候使用emit发布,第一个参数自定义一个名称,后面的参数是向父组件传的值
            // 可以是一个值,也可以是多个值,例如{name: zhangsan, id: 1}
            that.$emit('sonFun', that.sonData)  
        }
    }
}
</script>

父组件

<template>
    <div id="app">
        <img alt="Vue logo" src="./assets/logo.png" />
        <HelloWorld @sonFun="sonFun" /> <!-- 3.在父组件中的子组件上写上子组件传过来的事件,并用一个方法(方法名字随便定义)接收 -->
        子组件向父组件传过来的值=>{{faData}}
    </div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";  

export default {
    name: "App",
    components: {
        HelloWorld, 
    },
    data() {
        return {
            faData: null
        }
    },
    methods: {
        sonFun(e) {
            // 4.在方法中用一个实参e接收, 参数名字随便定义
            const that = this;
            that.faData = e
        }
    }
};
</script>

效果
在这里插入图片描述

兄弟组件传值(非父子组件):

在main.js中创建一个公共的vue实例

import Vue from 'vue'
import App from './App.vue'

Vue.config.productionTip = false

// 1.兄弟组件传值,需要创建一个公共的vue实例,在Vue的原型上创建一个属性bus,该属性的值为new Vue(),即bus也是一个vue实例
// 也可以新建一个js文件,兄弟两个组件分别引入这个js,
Vue.prototype.bus = new Vue() 

new Vue({
  render: h => h(App),
}).$mount('#app')

两个组件都需要在父组件中注册

<template>
    <div id="app">
        <img alt="Vue logo" src="./assets/logo.png" />
        <HelloWorld /> 
        <HiWorld />
    </div>
</template>

<script>
import HelloWorld from "./components/HelloWorld.vue";  
import HiWorld from "./components/HiWorld.vue";  

export default {
    name: "App",
    components: {
        HelloWorld, 
        HiWorld
    },
};
</script>

兄弟A组件

<template>
    <div class="hello">
        <button @click="doSend">点击</button> 
        <!-- 2.绑定一个事件或者是其他逻辑触发向兄弟发送值 -->
    </div>
</template>

<script>
export default {
    name: 'HelloWorld',
    data() {
        return {
            broData: '向兄弟传递的值'
        }
    },
    methods: {
        doSend() {
            const that = this;
            // 3.这里使用vue原型绑定的bus实例进行emit发布,兄弟组件传值就是一个是发布者emit,另一个是订阅者on
            that.bus.$emit('sendData', that.broData)
        }
    }
}
</script>

兄弟B组件

<template>
    <div>兄弟发送过来的值=> {{overData}}</div>
</template>

<script>
export default {
    data() {
        return {
            overData: null
        }
    },
    created() {
        const that = this;
        // 4.on可以写到created中或者mounted,第一个参数是兄弟传递过来的参数,后面跟一个回调函数,定一个参数来接收
        that.bus.$on('sendData', res=> {
            that.overData = res
        })
    }
}
</script>

效果
在这里插入图片描述
兄弟组件传值也可以用vuex状态管理,这里就不做讲解了

以上是vue2组件传值方式,vue3的也在努力编写中

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:09:15  更:2022-05-05 11:10:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 3:54:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码