【vue】defineEmits 传值 子传父

先行知识

传值流程


App.vue

html 复制代码
<template>
  <Header @getWeb="emitsGetWeb" @userAdd="emitsUserAdd"/>
  <hr />
  <p>web.name: {{ web.name }}</p>
  <p>web.url: {{ web.url }}</p>
  <p>user: {{ user }}</p>
</template>

<script setup>
import { ref, reactive } from "vue";
import Header from "./components/Header.vue";

//响应式数据
const web = reactive({
  name: "1234567890",
  url: "https://www.1234567890.com",
});
let user = ref(0);

const emitsGetWeb = (data) => { 
  console.log(data);
  web.name = data.name;
  web.url = data.url;
}
const emitsUserAdd = (data) => {
  console.log(data);
  user.value += data;
  console.log(user.value);
}
</script>

<style lang="scss" scoped></style>

Header.vue

html 复制代码
<template>
    <h2>header</h2>
    <button @click="userAdd">添加用户</button>
</template>

<script setup>

const emits = defineEmits(['getWeb', "userAdd"])

emits("getWeb", { name: "Header Name" , url: "Header Url"})

const userAdd = () => {
    emits("userAdd",1)
}
</script>

<style lang="scss" scoped></style>

参考

https://www.bilibili.com/video/BV1nV411Q7RX

相关推荐
破晓之翼13 分钟前
EASDEP 自动单据生成DEMO
javascript
阿珊和她的猫14 分钟前
Webpack 常用插件深度解析
前端·webpack·node.js
kylezhao201921 分钟前
第三节、C# 上位机面向对象编程详解(工控硬件封装实战版)
开发语言·前端·c#
行思理22 分钟前
css 样式新手教程
前端·css·html5
帅帅在睡觉1 小时前
组件的创建与挂载
javascript·vue.js·elementui
幽络源小助理1 小时前
基于SpringBoot+Vue的实验室管理系统源码 | 教育类JavaWeb项目免费下载 – 幽络源
vue.js·spring boot·后端
qq_406176141 小时前
JavaScript闭包:从底层原理到实战
开发语言·前端·javascript
冰暮流星1 小时前
javascript之Math对象——绝对值,开次方,四舍五入
前端·javascript
啊啊啊啊懒1 小时前
vite创建完项目之后vue文件中有标签报错
前端·javascript·vue.js
Knight_AL1 小时前
从 bootstrap.yml 到 Config Data 的一次架构升级
前端·架构·bootstrap