位置: IT常识 - 正文

使用 Vue3 开发了四个月,回顾 emit 的用法(使用vue开发app)

编辑:rootadmin
使用 Vue3 开发了四个月,回顾 emit 的用法 前言:不知不觉已经从 React 转 Vue3 开发四个多月了,但其实自从刚接触 vue 开始,就对 emit 这个指令似懂非懂。所以在项目中其实我还是很害怕去使用这个指令的,但是在有些场景又不得不使用,就只能看着同事的代码比葫芦画瓢去模仿他的写法... 但是在上周封装组件的时候,leader 说可以去查阅一下 v-model 的使用,于是我重新回顾了一下 vue 官方文档的相关知识,又经过去查阅别的博文,终于明白 emit 的思想。一.React 子组件修改 props 的思想理念通过 React 的官方文档我们可以了解到 React 的哲学思想是。如果子组件希望修改希望父亲组件传递过来的 props ,那么父组件也需要同时提供修改这个 props 的方法,因为对子组件来说,props 是一个只读属性,不允许进行任何修改。(这是有意而为之的,如果 props 可以被随意修改,那么就会导致整个项目状态的混乱)这里我们引用一下 React 官方文档中关于修改水温度的例子来解释。

推荐整理分享使用 Vue3 开发了四个月,回顾 emit 的用法(使用vue开发app),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3 key,vue3 key,vue3开发app,vue3.0开发,vue3 key,vue3开发app,vue3 key,vue3开始用了吗,内容如对您有帮助,希望把文章链接给更多的朋友!

        3.但是在某些场景中,我们在子组件中确实是需要去修改 props 的,那么这种场景该如何处理呢?

        4.这里就需要父组件在传递 props 的同时提供一个修改 props 的方法,(这个方法也是通过 props 传递的)

        5.这样做虽然有些繁琐,但是对于后期数据维护和修改代码是非常友好的,因为你可非常清楚的知道某一个 props 来自与那个父组件。

        6. 这里列举了一个简单的 demo ,大致用法如下所示:

二. Vue 子组件修改 props 的思想理念刚开始学习 vue 的时候,我有点先入为主的感觉了,感觉如果修改 props 的话,父组件就必须同时提供一个修改的方法。以为 vue 也是这样,其实也是可以的,vue 确实也可以通过 props 去同时提供这两样很重要的东西,并且功能是完全可以满足我们的需求的。

使用 Vue3 开发了四个月,回顾 emit 的用法(使用vue开发app)

        2. 但是这种想法其实和 vue 的理念有一点点违背,虽然我们都是避免了直接修改 props ,但是在 vue 里有它自己的理念。 我们先看一下 Vue 是怎么解释当子组件需要修改父组件提供的状态时的思想,最开始看到这里的时候,我其实没有特别理解画红线的意思。

        3.并且我们顺着官网的教程,去看 emit 指令的话,真的非常难以理解官方到底想表达什么想法。我承认 Vue 的中文官网也许是最适合国人学习的教程网站,但是它也有对萌新不是那么友好的地方。

        4.就像上面官网对 $emit 的解释一样,寥寥几笔,只留下我一人在风中凌乱。去搜索相关 $emit 相关的文章,有很多都是按照官网比葫芦画瓢的解释,真的非常不友好。

三. emit 的真正含义我们先看一下这个单词的原意,**“发射,发出”**的意思。这也是误导我很长时间的主要原因,因为我把这个 Vue 想表达的发射,理解成了把收到的 props 重新发射回去的意思,其实这是非常错误的理解。

        2.直到我学习了 v-model 指令的用法,我才彻底搞明白这个 “发射”,到底是想 “发射” 什么,它原来指的是 “发射” 一个修改 props 的通知,告诉父组件自己去修改 props。

        3.举个例子,我们改造一下上面我们通过传递两个 props(一个响应式状态,一个修改状态的方法)变为下面:

        4.你可以发现,原来通过 props 传递的 :addCount 变为了自定义事件 @addCount 的写法。

        5.⏰重点来了: 我相信很多初学者在看到父组件自定义一个事件这一章节的时候,会产生很大的疑问。其实这里 Vue 想表达的意思是,父组件注册了一个函数,但是它不会自己去执行这个函数,它需要收到一个信号才会自己去执行。什么叫注册了一个函数呢?说白了,就是它在自己本身组件内部定义了一个函数,但是这个函数在没有收到 “信号的时候是不会去执行的”。

        6.如果你能明白上一段的意思,那么你基本上就知道 “信号” 究竟是谁发出来的了。让我们回到子组件内部,在子组件内,我们需要去拿到父组件注册的那个函数名字。也就是addCount,来准备通知父组件。

        7.子组件内的按钮代表的意思就是,当我点击一次按钮,我就 “发射” 一个信号,告诉父组件去执行一次 addCount 这个函数,也就是在父组件里

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

上一篇:JS——正则表达式(超详细)(js正则用法)

下一篇:如何利用Linux命令检查和对比两个文件内容区别(linux如何使用)

  • iqoo8pro触控采样率是多少(iqoo8pro触控采样率只有121)

    iqoo8pro触控采样率是多少(iqoo8pro触控采样率只有121)

  • 交管12123怎么查询预约结果(交管12123怎么查询非本人车辆违章)

    交管12123怎么查询预约结果(交管12123怎么查询非本人车辆违章)

  • 小米手机能用几年(小米手机能用几个小时)

    小米手机能用几年(小米手机能用几个小时)

  • 在word文档中不可直接操作的是(在word文档中不能作为文本转换为表格的分隔符是)

    在word文档中不可直接操作的是(在word文档中不能作为文本转换为表格的分隔符是)

  • 嘀嗒出行1+1是什么意思(嘀嗒出行规则)

    嘀嗒出行1+1是什么意思(嘀嗒出行规则)

  • 551怎么删除成员(551家庭网怎么删除成员)

    551怎么删除成员(551家庭网怎么删除成员)

  • 视频怎么以文件形式发送给QQ好友(视频怎么以文件形式发送微信)

    视频怎么以文件形式发送给QQ好友(视频怎么以文件形式发送微信)

  • 电脑网线插路由器哪个口(电脑网线插路由器上就能用吗)

    电脑网线插路由器哪个口(电脑网线插路由器上就能用吗)

  • 微信更换实名制零钱会被清空吗(微信更换实名制后账单还能导出来么)

    微信更换实名制零钱会被清空吗(微信更换实名制后账单还能导出来么)

  • 数据删除和数据擦除的区别(数据删除和数据清除的概念)

    数据删除和数据擦除的区别(数据删除和数据清除的概念)

  • 手机充不满电是怎么回事(手机充不满电是电池的问题吗)

    手机充不满电是怎么回事(手机充不满电是电池的问题吗)

  • 双系统开机时按哪个键(双系统开机按F)

    双系统开机时按哪个键(双系统开机按F)

  • 钉钉老师能主动连麦吗(钉钉老师主动和你连麦用电脑怎么关摄像头)

    钉钉老师能主动连麦吗(钉钉老师主动和你连麦用电脑怎么关摄像头)

  • word里的除号在哪里(word中的除号怎么输入)

    word里的除号在哪里(word中的除号怎么输入)

  • 手机副卡怎么取消(手机副卡怎么取消流量套餐)

    手机副卡怎么取消(手机副卡怎么取消流量套餐)

  • 华为mate30pro进水后怎么办(华为mate30pro进水了)

    华为mate30pro进水后怎么办(华为mate30pro进水了)

  • 单模光纤中间接一段多模可以吗(单模光纤断了怎么接)

    单模光纤中间接一段多模可以吗(单模光纤断了怎么接)

  • 我的苹果11怎么不是双卡(我的苹果11怎么没有录屏)

    我的苹果11怎么不是双卡(我的苹果11怎么没有录屏)

  • 探探是哪一年上线的(探探是哪一年上市的软件)

    探探是哪一年上线的(探探是哪一年上市的软件)

  • iphone的原彩显示有什么用(iphone的原彩显示伤眼睛吗)

    iphone的原彩显示有什么用(iphone的原彩显示伤眼睛吗)

  • 微信小程序内存怎么清理(微信小程序内存不足闪退怎么办)

    微信小程序内存怎么清理(微信小程序内存不足闪退怎么办)

  • ps反相快捷键(ps下一页)

    ps反相快捷键(ps下一页)

  • 华为手机后面的进网许可可以撕吗(华为手机后面的标签怎么弄掉)

    华为手机后面的进网许可可以撕吗(华为手机后面的标签怎么弄掉)

  • 怎么把电量变成七彩的(怎么把电量变成图案)

    怎么把电量变成七彩的(怎么把电量变成图案)

  • 最高频率的内存是什么(最高频率内存条是多少)

    最高频率的内存是什么(最高频率内存条是多少)

  • 【JavaScript速成之路】一文带你掌握DOM基础(javascript最好的教程)

    【JavaScript速成之路】一文带你掌握DOM基础(javascript最好的教程)

  • 收购农副产品怎么做账
  • 辞退员工补偿金是按实发工资算还是应发
  • 一般纳税人和小规模纳税人的区别
  • 企业出现税务问题的案例
  • 劳务派遣人员工作单位怎么写
  • 代理缴费业务主要包括
  • 外资企业享受什么优惠政策
  • 企业外汇买卖业务流程图
  • 自建模具怎么做账
  • 电子商票贴现具备的条件
  • 土地使用税怎么征收标准
  • 进项税留底是什么意思
  • 税控设备全额抵扣政策
  • 转让金融资产的税率
  • 没有收到发票的支出可以做成本吗
  • 实收资本印花税是一年一交吗
  • 增值税纳税表销售额的填写
  • 用于非增值税应交税费
  • 增值税代扣代缴抵扣
  • 农贸市场收取管理费
  • 增值税抵扣需要哪些附件
  • 存货跌价准备用账面余额还是账面价值
  • 抽奖得奖
  • 小规模纳税人增值税免税政策
  • 母子公司吸收合并优劣势
  • 期货公司保证金怎么算的
  • 公司的净资产总值怎么算
  • php ftp功能
  • PHP:time_sleep_until()的用法_misc函数
  • 无形资产的界定及特点
  • 员工离职的类型
  • 日本福吉山
  • 商品进销差价的作用
  • 非金融机构从事贷款谁负责监管
  • php使用自定义函数编程求半径r的圆的周长和面积
  • 【角色扮演】
  • XF86Setup命令 设置XFee86
  • git t
  • 金融资产的会计科目
  • react避免子组件更新
  • 个体户怎么报增值税
  • 加工行业增值税负率一般控制在多少?
  • 运营费的税率
  • 净现值与原始投资额现值
  • 会影响当期损益的科目有
  • 以前年度亏损要调整吗
  • 单位财务报销制度和流程
  • 小规模纳税人能开6%增值税专用发票吗
  • 刚购入的固定资产已使用年限怎么填
  • 内含增长率的推导
  • 补交以前年度增值税如何入账
  • 汇算清缴怎么申报
  • 余额调节表的模板
  • 购进生产设备的进项税额抵扣政策
  • 销售货物没开票是不是不交税
  • 日常修理费用如何记账
  • 代理记账许可证查询
  • navicat不能创建string类型
  • sql提取指定字符串
  • 如何开启windows防火墙
  • win7系统怎么合并分区
  • FNPLicensingService.exe是什么意思
  • 如何查看win10版本是不是正版
  • u盘pe安装win7系统
  • linux的tar
  • drivemgr.exe 病毒介绍
  • 解决安全问题的有效途径
  • centos6.2安装教程
  • centos删除virbr0
  • win7系统搜索在哪
  • 一键快速关机下载手机版
  • windows隐藏分区
  • windows8触屏功能
  • shell产生随机字符串
  • cocos2dx schedule
  • 什么叫真游戏
  • 查看linux中某个端口(port)是否被占用的方法
  • 火药概念股有哪些
  • 北京市国家税务局发票查询
  • 财税65号第一条
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设