Vue3通信方式之defineProps、defineEmits、useAttrs、插件mitt和v-model

这篇具有很好参考价值的文章主要介绍了Vue3通信方式之defineProps、defineEmits、useAttrs、插件mitt和v-model。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、使用defineProps

props可以实现父子组件通信,在vue3中我们可以通过defineProps获取父组件传递的数据。且在组件内部不需要引入defineProps方法可以直接使用!

父组件给子组件传递数据

    <Child info="我爱祖国" :money="money"></Child>

子组件获取父组件传递数据:方式1

    let props = defineProps({
      info:{
       type:String,//接受的数据类型
       default:'默认参数',//接受默认数据
      },
      money:{
       type:Number,
       default:0
    }})

子组件获取父组件传递数据:方式2

    let props = defineProps(["info",'money']);

子组件获取到props数据就可以在模板中使用了,但是切记props是只读的(只能读取,不能修改)

2、使用defineEmits接受自定义事件

在vue框架中事件分为两种:一种是原生的DOM事件,另外一种自定义事件。

原生DOM事件可以让用户与网页进行交互,比如click、dbclick、change、mouseenter、mouseleave…

自定义事件可以实现子组件给父组件传递数据

2.1原生DOM事件

代码如下:

     <pre @click="handler">
          我是祖国的老花骨朵
     </pre>

当前代码级给pre标签绑定原生DOM事件点击事件,默认会给事件回调注入event事件对象。当然点击事件想注入多个参数可以按照下图操作。但是切记注入的事件对象务必叫做$event.

      <div @click="handler1(1,2,3,$event)">我要传递多个参数</div>

在vue3框架click、dbclick、change(这类原生DOM事件),不管是在标签、自定义标签上(组件标签)都是原生DOM事件。

2.2自定义事件

自定义事件可以实现子组件给父组件传递数据.在项目中是比较常用的。

比如在父组件内部给子组件(Event2)绑定一个自定义事件

    <Event2  @xxx="handler3"></Event2>

在Event2子组件内部触发这个自定义事件

    <template>
      <div>
        <h1>我是子组件2</h1>
        <button @click="handler">点击我触发xxx自定义事件</button>
      </div>
    </template>
    
    <script setup lang="ts">
    let $emit = defineEmits(["xxx"]);
    const handler = () => {
      $emit("xxx", "法拉利", "茅台");
    };
    </script>
    <style scoped>
    </style>

我们会发现在script标签内部,使用了defineEmits方法,此方法是vue3提供的方法,不需要引入直接使用。defineEmits方法执行,传递一个数组,数组元素即为将来组件需要触发的自定义事件类型,此方执行会返回一个$emit方法用于触发自定义事件。

当点击按钮的时候,事件回调内部调用$emit方法去触发自定义事件,第一个参数为触发事件类型,第二个、三个、N个参数即为传递给父组件的数据。

需要注意的是:代码如下

    <Event2  @xxx="handler3" @click="handler"></Event2>

正常说组件标签书写@click应该为原生DOM事件,但是如果子组件内部通过defineEmits定义就变为自定义事件了

    let $emit = defineEmits(["xxx",'click']);

3、全局事件总线(插件mitt)

全局事件总线可以实现任意组件通信,在vue2中可以根据VM与VC关系推出全局事件总线。

但是在vue3中没有Vue构造函数,也就没有Vue.prototype.以及组合式API写法没有this,

那么在Vue3想实现全局事件的总线功能就有点不现实啦,如果想在Vue3中使用全局事件总线功能

可以使用插件mitt实现。

mitt:官网地址:https://www.npmjs.com/package/mitt

4、v-model

v-model指令可是收集表单数据(数据双向绑定),除此之外它也可以实现父子组件数据同步。

而v-model实指利用props[modelValue]与自定义事件[update:modelValue]实现的。

下方代码:相当于给组件Child传递一个props(modelValue)与绑定一个自定义事件update:modelValue
实现父子组件数据同步

    <Child v-model="msg"></Child>

在vue3中一个组件可以通过使用多个v-model,让父子组件多个数据同步,下方代码相当于给组件Child传递两个props分别是pageNo与pageSize,以及绑定两个自定义事件update:pageNo与update:pageSize实现父子数据同步

    <Child v-model:pageNo="msg" v-model:pageSize="msg1"></Child>

5、useAttrs

使用vue中的useAttrs方法可以获取组件标签上的属性和事件。

两个组件分别为父组件app.vue和子组件helloworld.vue

父组件:

<template>
  <el-button type="primary" size="small" :icon="Edit"></el-button>
  <HelloWorld msg="我是helloword子组件" type="primary" size="small" :icon="Edit" title="你好编辑" />
</template>

<script setup lang="ts">
  import HelloWorld from './components/HelloWorld.vue'
  import {
    Edit,
    Delete
  } from '@element-plus/icons-vue'
</script>

<style scoped>

</style>

子组件:

<template>


  <div class="card" :title="$attrs.title">
    <h3>{{ msg }}</h3>
    <el-button :="$attrs"></el-button>
  </div>

</template>

<script setup lang="ts">
  import {
    ref
  } from 'vue'
  import {
    useAttrs
  } from 'vue'

  let $attrs = useAttrs()
  console.log($attrs)

  defineProps < {
    msg: string
  } > ()

  const count = ref(0)
</script>

<style scoped>
  .card {
    background-color: antiquewhite;
  }

  .read-the-docs {
    color: #888;
  }
</style>

上述代码中,首先在父组件中引入子组件:

import HelloWorld from './components/HelloWorld.vue'

在父组件中,子组件标签上加上所需属性:

<HelloWorld msg="我是helloword子组件" type="primary" size="small" :icon="Edit" title="你好编辑" />

然后在子组件中引入vue中的useAttrs方法:

  import {
    useAttrs
  } from 'vue'

useAttrs方法返回的是一个对象

  let $attrs = useAttrs()
  console.log($attrs)

打印输出这个对象:
Vue3通信方式之defineProps、defineEmits、useAttrs、插件mitt和v-model,javascript,开发语言,ecmascript
可以看到输出结果中,能接受到父组件标签中的属性值。

最后在子组件中属性绑定$attrs的值:

<el-button :="$attrs"></el-button>

注意事项(重点)

需要注意的是:props和useAttrs方法都可以获取到父组件传过来来的属性和属性值;
但是如果一旦用prop接受了其中的某个属性和属性值,那么useAttrs就接受不到这个属性和属性值。文章来源地址https://www.toymoban.com/news/detail-678601.html

到了这里,关于Vue3通信方式之defineProps、defineEmits、useAttrs、插件mitt和v-model的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • vue3 useAttrs的使用场景,提取共有props

    vue3 useAttrs的使用场景,提取共有props

    多个类似组件都需要传参data,用于请求接口或者处理数据,想让组件干净整洁,把参数data提出来 选项式 可以使用mixin混入或者extends继承(略) 组合式 可以使用hook 无脑式踩坑(如下代码): // hook // component 当在组件中引用hook后,控制台会警告,同时组件无法渲染 解决方

    2024年02月02日
    浏览(10)
  • vue3 defineEmits

    简介:用于父子组件通信时,子组件向父组件传递数据,不需要被导入即可使用,会在编译 script setup 语法块时一同编译。注意的是 defineEmits 只能在 script setup 的顶层使用 使用 1、定义子组件 2、定义父组件

    2024年02月09日
    浏览(8)
  • vue3 defineEmits的使用

    vue3 defineEmits的使用

    以下代码和内容的使用都是在vue3的setup中,未使用TS。 1、计数器案例 父组件: 子组件: 页面渲染效果 2、案例说明 1、在父组件中定义一个变量 2、在子组件中定义+1和-1方法,以及一个变量 3、通过子组件事件修改变量值,同时将值传递给父组件,对父组件的变量进行赋值

    2024年02月12日
    浏览(5)
  • vue3的组件事件和defineEmits

    vue3的组件事件和defineEmits

    子组件有时候需要与父组件进行交互,子组件需要通知父组件做一些事(比如:prop是单向数据量,子组件不应该直接修改prop绑定的值,而是应该 抛出一个事件来通知父组件做出改变 ) 为了解决这个问题,组件实例提供了一个自定义事件系统,父组件可以通过 v-on 或 @ 来选

    2024年02月09日
    浏览(12)
  • vue3+vue-cli 报错 ‘defineProps‘ is not defined

    vue3+vue-cli 报错 ‘defineProps‘ is not defined

      确保这些都存在,仍报错则需要修改node版本的 本人改到最新版就没什么问题了

    2024年02月12日
    浏览(38)
  • 【vue3】学习笔记--组件通信方式

    【vue3】学习笔记--组件通信方式

    学习vue3总是绕不开vue2 vue3组件通信方式如下: props数据只读,从父组件传递到子组件,子组件内部不可直接更改 子组件需要使用defineProps方法接受父组件传递过来的数据 setup语法糖下局部组件无需注册直接可以使用 父组件 子组件 vue框架中事件分为两种:原生的DOM事件和自定

    2024年02月13日
    浏览(14)
  • Vue3组件间的通信方式

    Vue3组件间的通信方式

    目录  1.props父向子组件通信 2.自定义事件 子向父组件通信 3.全局事件总线 4.v-model组件通信(父子组件数据同步) 绑定单个数据同步  绑定多个数据同步  5.useAttrs组件通信  6.ref与$parent ref获取子组件实例对象  $parent获取父组件实例对象  7.provide-inject 可以实现隔辈传输 8.

    2024年02月17日
    浏览(11)
  • vue3 组件间通信的方式(setup语法糖写法)

    该方式用于父传子,父组件以数据绑定的形式声明要传递的数据,子组件通过defineProps()方法创建props对象,即可拿到父组件传来的数据。 2. emit方式 emit 方式也是Vue中最常见的组件通信方式,该方式用于 子传父。 3、defineExpose 利用defineExpose+ref 可以得到组件里的方法和变量

    2024年02月12日
    浏览(10)
  • vue3 v-for遍历defineProps或者props接收的数据时,报“xx” is of type ‘unknown‘

    vue3 v-for遍历defineProps或者props接收的数据时,报“xx” is of type ‘unknown‘

    vue中使用ts,且在使用props或者defineProps进行父传子时,v-for遍历收到的数组,进行取值时,报“xx” is of type \\\'unknown\\\' 提示:ts进行类型推导造成的报错 提示:使用接口进行 提示:创建一个ts文件,放类型数据,在使用的页面进行引用            总结:前两个都有一个弊端,

    2024年02月16日
    浏览(12)
  • vue3自动引入插件unplugin-auto-import (vite搭建项目,vue-cli搭建项目两种方式)

    vue3自动引入插件unplugin-auto-import (vite搭建项目,vue-cli搭建项目两种方式)

    插件地址:https://github.com/antfu/unplugin-auto-import 如果安装了eslint,使用的ref、torefs等报错undefind如下图 需在2个地方vue.config.js ,.eslintrc.js文件做配置 代码:

    2024年02月13日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包