iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >VUE父子组件通信乱斗:谁才是真正的赢家?
  • 0
分享到

VUE父子组件通信乱斗:谁才是真正的赢家?

摘要

在vue.js中,父子组件通信是一个常见的需求。有五种主要的方法可以实现父子组件通信,分别是props、$emit、$refs、provide/inject和自定义事件。每种方法都有其各自的优缺点,在不同的场景下使用不同的方法可以实现更

vue.js中,父子组件通信是一个常见的需求。有五种主要的方法可以实现父子组件通信,分别是props、$emit、$refs、provide/inject和自定义事件。每种方法都有其各自的优缺点,在不同的场景下使用不同的方法可以实现更好的效果。

1. props

props是props(properties)的缩写,它是子组件从父组件接收数据的常用方法。父组件通过在子组件的template标签中声明props,子组件通过在data()方法中定义props来接收数据。

<!-- 父组件 -->
<template>
  <child-component :message="message"></child-component>
</template>

<script>
export default {
  data() {
    return {
      message: "Hello, world!"
    }
  }
}
</script>

<!-- 子组件 -->
<template>
  <div>{{ message }}</div>
</template>

<script>
export default {
  props: ["message"],
  data() {
    return {}
  }
}
</script>

2. $emit

$emit是emit(触发)的缩写,它是子组件向父组件发送事件的常用方法。子组件通过调用$emit()方法来触发事件,父组件通过在子组件的template标签中声明@事件名来监听事件。

<!-- 父组件 -->
<template>
  <child-component @message="handleMessage"></child-component>
</template>

<script>
export default {
  methods: {
    handleMessage(message) {
      console.log(message)
    }
  }
}
</script>

<!-- 子组件 -->
<template>
  <button @click="handleClick">点击我</button>
</template>

<script>
export default {
  methods: {
    handleClick() {
      this.$emit("message", "Hello, world!")
    }
  }
}
</script>

3. $refs

$refs是refs(引用)的缩写,它是父组件访问子组件实例的常用方法。父组件通过在子组件的template标签中声明ref,子组件通过在data()方法中定义ref来暴露实例。

<!-- 父组件 -->
<template>
  <child-component ref="child"></child-component>
</template>

<script>
export default {
  mounted() {
    console.log(this.$refs.child)
  }
}
</script>

<!-- 子组件 -->
<template>
  <div>我是子组件</div>
</template>

<script>
export default {
  data() {
    return {}
  }
}
</script>

4. provide/inject

provide/inject是Vue.js 2.2.0引入的新特性,它是一种父子组件间通信方式。父组件通过provide()方法提供数据,子组件通过inject()方法注入数据。

<!-- 父组件 -->
<template>
  <provide>
    <child-component></child-component>
  </provide>
</template>

<script>
export default {
  provide() {
    return {
      message: "Hello, world!"
    }
  }
}
</script>

<!-- 子组件 -->
<template>
  <div>{{ message }}</div>
</template>

<script>
export default {
  inject: ["message"],
  data() {
    return {}
  }
}
</script>

5. 自定义事件

自定义事件是通过dispatchEvent()方法触发,addEventListener()方法监听的事件。

<!-- 父组件 -->
<template>
  <button @click="handleClick">点击我</button>
</template>

<script>
export default {
  methods: {
    handleClick() {
      dispatchEvent(new CustomEvent("message", { detail: "Hello, world!" }))
    }
  }
}
</script>

<!-- 子组件 -->
<template>
  <div>
    <button @click="handleMessage">点击我</button>
    <p id="message"></p>
  </div>
</template>

<script>
export default {
  methods: {
    handleMessage() {
      addEventListener("message", (event) => {
        document.getElementById("message").innerText = event.detail
      })
    }
  }
}
</script>

以上五种方法各有优缺点,在不同的场景下使用不同的方法可以实现更好的效果。

--结束END--

本文标题: VUE父子组件通信乱斗:谁才是真正的赢家?

本文链接: https://www.lsjlt.com/news/561715.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • VUE父子组件通信乱斗:谁才是真正的赢家?
    在Vue.js中,父子组件通信是一个常见的需求。有五种主要的方法可以实现父子组件通信,分别是props、$emit、$refs、provide/inject和自定义事件。每种方法都有其各自的优缺点,在不同的场景下使用不同的方法可以实现更...
    99+
    2024-02-07
    Vue.js 父子组件通信 props $emit $refs provide/inject 自定义事件
  • VUE父子组件通信指南:从小白到专家
    Vue父子组件通信是组件化开发的核心,它允许子组件与父组件之间传递数据和方法。掌握Vue父子组件通信的原理和方法,对于构建复杂的前端应用至关重要。 在Vue中,父子组件通信可以通过多种方式实现,常见的有prop、emit、$emit、$o...
    99+
    2024-02-07
    Vue 父子组件通信 prop emit $emit $on provide inject
  • 父子聊通讯:揭秘 VUE 父子组件通信的那些事儿
    父子组件通信是VUE中非常重要的一个概念,它允许父子组件之间进行数据传递和事件触发。在VUE中,父子组件通信可以通过以下几种方式实现: Props: Props是VUE中实现父子组件通信最常用的方式。它允许父组件将数据传递给子组件。 ...
    99+
    2024-02-07
    文章 VUE 父子组件通信 props $emit ref $children $parent
  • Vue中父子组件间怎么通信的
    本篇内容主要讲解“Vue中父子组件间怎么通信的”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue中父子组件间怎么通信的”吧!Vue父子组件什么是父子组件?在一个组件中引入另一个组件,被引入的就...
    99+
    2023-06-21
  • Vue组件及父子组件通信的示例分析
    这篇文章将为大家详细讲解有关Vue组件及父子组件通信的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是组件?vue中的组件其实就是页面组成的一部分,好比是电脑...
    99+
    2024-04-02
  • vue父子组件进行通信方式是怎样的
    这篇文章主要介绍“vue父子组件进行通信方式是怎样的”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue父子组件进行通信方式是怎样的”文章能帮助大家解决问题。如图所示,父组件向子组件传递数据,可以通...
    99+
    2023-06-29
  • Vue中父子组件间通信的方法是什么
    这篇文章主要讲解了“Vue中父子组件间通信的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中父子组件间通信的方法是什么”吧!1、父组件传递给子组件父组件传递给子组件:通过pr...
    99+
    2023-07-04
  • Vue实现非父子组件通信的方法是什么
    本篇内容介绍了“Vue实现非父子组件通信的方法是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!组件是Vue核心的一块内容,组件之间的通信...
    99+
    2023-07-04
  • VUE父子组件通信的未来:下一代通信方式是什么?
    父子组件通信是VUE中一种常用的组件通信方式,它允许父组件直接访问子组件的数据和方法。这种通信方式简单易用,但它存在一些局限性。例如,它只能在父子组件之间进行通信,而且父组件不能访问子组件的内部状态。 为了解决这些问题,下一代组件通信方...
    99+
    2024-02-07
    VUE 组件通信 父子组件通信 下一代组件通信
  • vue中如何实现非父子组件的通信
    这篇文章主要介绍了vue中如何实现非父子组件的通信,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、Provide和InjectProvide和Inject用于非父子组件之间...
    99+
    2023-06-29
  • 解决父子组件通信的三种Vue插槽
    目录前言环境准备Category组件App组件一、默认插槽二、具名插槽三、作用域插槽总结 前言 插槽可以说是 Vue 中非常重要的一部分吧,在我学习和练习的过程中,当组件搭配着插槽一...
    99+
    2024-04-02
  • vue组件间的通信,子组件向父组件传值的方式是什么
    今天小编给大家分享一下vue组件间的通信,子组件向父组件传值的方式是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、子...
    99+
    2023-07-05
  • vue中非父子组件的通信你了解吗
    目录一、Provide和Inject二、Provide和Inject的另一种写法三、全局事件总线mitt库总结我们总结了父子组件通信方式有:props + emi...
    99+
    2024-04-02
  • vue父子组件进行通信方式原来是这样的
    目录一、props二、细节三props大小写命名三、非props的attributes属性四、子组件传递给父组件五、简单例子总结在vue中如何实现父子组件通信,本篇博客将会详细介绍父...
    99+
    2024-04-02
  • Vue中父子组件通信与事件触发的方法
    这篇文章主要讲解了“Vue中父子组件通信与事件触发的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue中父子组件通信与事件触发的方法”吧!一、组件子组件<template>...
    99+
    2023-06-29
  • Vue非父子组件之间的通信方式详解
    目录非父子组件的通信1.Provide和Inject1.1基本使用1.2处理响应式数据(了解)2.全局事件总线总结非父子组件的通信 此篇讲解的是, 在学习状态管理之前, 非父子间通信...
    99+
    2024-04-02
  • 解决父子组件通信的Vue插槽有哪些
    小编给大家分享一下解决父子组件通信的Vue插槽有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!环境准备先搭个初始环境给大家看看哈。一步一步讲完这个插槽。就是写...
    99+
    2023-06-21
  • vue组件间的通信,子组件向父组件传值的方式汇总
    目录一、子组件通过this.$emit()的方式将值传递给父组件二、通过vuex来传递组件间的数据三、通过中央总线来传递组件间的数据四、通过修改父组件传过来的对象属性五、父组件使用子...
    99+
    2023-03-20
    vue组件通信 vue子组件 vue父组件传值
  • React父子组件间的通信是怎样进行的
    目录父子组件通信方式父传子子传父ref标记(传递数据)非父子组件通信方式状态提升(兄弟通信)发布订阅模式context状态树传参(跨组件方案)React插槽children实现插槽多...
    99+
    2023-03-14
    React父子组件通信 React组件通信
  • Vue如何实现父子组件之间的通信功能
    这篇文章主要为大家展示了“Vue如何实现父子组件之间的通信功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Vue如何实现父子组件之间的通信功能”这篇文章吧。在...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作