位置: IT常识 - 正文

VUE3传值相关六种方法(vue传值inject)

编辑:rootadmin
VUE3传值相关六种方法

目录

1.父传子(props)

 2.子传父组件方法和值(emit)

 3.子传父(v-model)

4.父组件调用子组件方法(ref)

5.VUEX

推荐整理分享VUE3传值相关六种方法(vue传值inject),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue三种传值方式,vue传值bus,vue三种传值方式,vue值传递,vue中传值的方式,vue三种传值方式,vue3.0传值,vue3.0传值,内容如对您有帮助,希望把文章链接给更多的朋友!

6.第六种爷孙传值provide / inject(官方并不建议未总结)

1.父传子(props)

VUE3父传子

1.将fatherToChild的值传递到index子组件之中并且在父组件中操作按钮子组件数据会跟随变化

<div class="bgc fed"> <div class="father"> <p>我是父组件</p> <p> <button @click="changeFather">更改父组件数值</button> </p> </div> <index :fatherToChild="fatherToChild" /> </div>

2.引入vue的import

import { defineComponent, ref, reactive, toRefs } from "vue";

3.const 所要传递的数据并且写上父组件的按钮方法

const state = reactive({ fatherToChild: "fatherToChild", }); const changeFather = () => { state.fatherToChild = "changeFather"; }; return { ...toRefs(state), changeFather, };

如图所示为一开始传递fatherToChild在点击按钮之后传递数值变为changeFather

4.在子组件之中接收所传递的props

export default { props: { fatherToChild: String, }, setup(props) { return { props, }; },};

如果不确定传值为什么可cons一下传递的props在控制台观察

在子组件中引用为

<p>父组件给子组件传值:{{ props.fatherToChild }}</p>

效果如图所示

可以观察到点击父组件后子组件数值跟随变化

 2.子传父组件方法和值(emit)

同VUE2一样子组件没有办法直接更改父组件方法,选用context.emit进行方法传递

1.子组件之中写方法触发context,emit

setup(props, context) { const childChangeFather = () => { context.emit("childUseFather", "childUseFather"); }; return { props, childChangeFather, }; },

context.emit(‘方法名’,数值)

 2.父组件之中接收方法后调用更改数值

const childUseFather = (val) => { state.fatherToChild = val; }; <index :fatherToChild="fatherToChild" @childUseFather="childUseFather" />

效果如图所示

VUE3传值相关六种方法(vue传值inject)

点击前点击后

 3.子传父(v-model)

如果子传父所更改的值恰好跟父组件相同可用v-model

1.父组件之中

<index v-model:fatherToChild="fatherToChild" />

 不再需要使用@和:

2.子组件之中

const modelChange = () => { context.emit("update:fatherToChild", "modelChangeFather"); };

使用update方法,context.emit("update:方法名","传值")

效果如图所示

点击前点击后

 同时父组件更改数值子组件也会同样跟随变化

4.父组件调用子组件方法(ref)

就是使用 ref 来获取dom 然后操作里面的参数和方法。

父组件之中

<p><button @click="fatherUse">ref父组件调用子组件方法</button></p> <index ref="child" /> const child = ref(); const fatherUse = () => { child.value.fatherUseChild("fatherChangeChild"); };

在组件上绑定ref,起名为child在调用时使用child.value.方法名(“传值”)

子组件之中

const state = reactive({ children: "children", }); // 父组件调用子组件方法并且进行传值更改 const fatherUseChild = (val) => { console.log("调用成功"); state.children = val; };

接收到传值val,触发方法给children重新赋值

效果如图所示

点击最后一个按钮父组件调用时

可以观察到子组件之中子组件的值变化为fatherChangeChild 

5.VUEX

文件目录结构如图所示

 index.js之中

import { createStore } from 'vuex'import {state} from './state'import {mutations} from './mutations'import {actions} from './actions'export default createStore({ state, mutations, actions, modules: { }})

注意如果引入的时候没写{}在后续会导致store.state.字段找不到,需要store.state.state.字段才能查到数据,只有好不好用就不知道了= =

首先在state之中

本文链接地址:https://www.jiuchutong.com/zhishi/294561.html 转载请保留说明!

上一篇:uniapp封装axios?大可不必那么麻烦。(uniapp封装组件,多了一层)

下一篇:创建vue2项目(vue创建项目后开始写的步骤)

  • 坏账准备需要计提成本吗
  • 增量留抵税额怎么做分录
  • 营业收入比销售商品收到的现金少
  • 虚开普票的立案标准
  • 调拨单可以根据哪些单据生成
  • 个人代人开普票个税怎么算
  • 政府补助应计入
  • 房屋租赁合同印花税计税依据
  • 股东打入公户的钱怎么做账
  • 减免的增值税如何账务处理
  • 医院的重要性
  • 事业单位预算外收入
  • 记账凭证一定要签字吗
  • 已付款未收到发票
  • 非公司员工可以交社保吗
  • 2019小规模纳税人增值税起征点
  • 个体虚开普通发票罪立案标准
  • 增值税减免税申报明细表免税代码和名称
  • 机械租赁的发票
  • ppt另存为在哪儿
  • 购房专票可以抵扣进项税吗为什么
  • wifi上传速度为0的解决方法
  • 鸿蒙系统桌面布局图片怎么设置
  • 公司退股需要交什么税
  • 收到政府补贴的装修款
  • 车间购买办公用品
  • 公司取得的营业收入
  • 苹果手机查找对方手机位置看不到
  • 企业职工工伤赔偿标准
  • windows 7怎么打开虚拟化
  • yoosee怎么安装
  • 高新企业研发支出转产成品
  • PHP:highlight_string()的用法_misc函数
  • 委托代销商品的科目编码
  • php未定义数组下标0
  • 收到支票直接背书账务
  • php升级到php7注意的问题
  • 不得领购使用增值税专用发票
  • 民非企业保险支出包括
  • php ucwords() 函数将字符串中每个单词的首字符转换为大写(实现代码)
  • k8s控制器模式
  • 交易性金融资产属于流动资产
  • 知识图谱ui
  • php+vue
  • 核定征收的纳税人能否享受六税两费减免
  • 开票软件的证书口令是多少
  • 外购商品转为自用固定资产,进项税
  • 房屋租赁费需要分摊吗
  • 生产成品出库的会计分录
  • 计提增值税如何计算
  • 应交税费年末需要结转吗
  • 销售过程中发生的商业折扣计入
  • 存货管理的类型
  • 长期股权投资损益调整
  • 固定资产的进项税额可以一次性抵扣吗
  • 直接减免增值税计入其他收益
  • 顺风车没有发票是否合法
  • 资金股东占股比例
  • 差旅费住宿专票能否抵扣
  • 错误凭证如何处理
  • 其他非流动资产包括哪些
  • win8桌面图标不显示
  • linux给root权限
  • linux限制用户登录
  • mac 默认设置
  • windows8如何使用
  • Cocos2dx CCSprite CCSpriteFrame CCTexture2D CCAnimation学习总结
  • python获取当前路径的方法
  • python3循环语句
  • 2020 unity
  • 深入理解python特性 pdf
  • android support包
  • js判断设备
  • js写日期
  • ActivityManager: Warning: Activity not started, its current task has been brought to the front 的的问题
  • flask框架下使用scrapy框架
  • 环保税征收标准可以改吗
  • 税控盘税务数字证书密码忘记怎么办
  • 个体非正常户怎么解除
  • 新时代新思想基层医疗宣讲
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设