位置: 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如何使用)

  • airpods可以分开独立使用吗(airpods可以分开用吗)

    airpods可以分开独立使用吗(airpods可以分开用吗)

  • 天猫精灵怎么更改音色(天猫精灵怎么更改唤醒名字)

    天猫精灵怎么更改音色(天猫精灵怎么更改唤醒名字)

  • qlv格式用什么播放器(qlv格式什么播放器好用)

    qlv格式用什么播放器(qlv格式什么播放器好用)

  • 打印机保修期是多长时间(打印机的保修期)

    打印机保修期是多长时间(打印机的保修期)

  • iq00neo和iq00区别(vivo iq00和 neo对比)

    iq00neo和iq00区别(vivo iq00和 neo对比)

  • 抖音昵称怎么改不了,说已被认证(抖音昵称怎么改不过来怎么办)

    抖音昵称怎么改不了,说已被认证(抖音昵称怎么改不过来怎么办)

  • 抖音上工会勿扰什么意思(抖音上工会勿扰啥意思)

    抖音上工会勿扰什么意思(抖音上工会勿扰啥意思)

  • qq爱为什么听不了(歌曲qq爱怎么没了)

    qq爱为什么听不了(歌曲qq爱怎么没了)

  • 苹果蓝牙为什么第二天自动开启(苹果蓝牙为什么连不上)

    苹果蓝牙为什么第二天自动开启(苹果蓝牙为什么连不上)

  • 钉钉能看到学生分屏吗(钉钉能看到学生切屏吗)

    钉钉能看到学生分屏吗(钉钉能看到学生切屏吗)

  • 电脑开机后蓝屏显示英文(联想电脑开机后蓝屏)

    电脑开机后蓝屏显示英文(联想电脑开机后蓝屏)

  • 苹果的屏幕分辨率(苹果的屏幕分辨率是多少)

    苹果的屏幕分辨率(苹果的屏幕分辨率是多少)

  • 9700核显什么水平(9700k核显水平)

    9700核显什么水平(9700k核显水平)

  • 传真安装程序是什么意思(传真安装程序怎么解决)

    传真安装程序是什么意思(传真安装程序怎么解决)

  • 安卓手机录制屏幕在哪(安卓手机录制屏幕教程)

    安卓手机录制屏幕在哪(安卓手机录制屏幕教程)

  • 拼多多我的账户在哪里(拼多多我的账户余额在哪里)

    拼多多我的账户在哪里(拼多多我的账户余额在哪里)

  • 怎么通过qq找到别人的手机号(怎么通过QQ找到微信)

    怎么通过qq找到别人的手机号(怎么通过QQ找到微信)

  • 手机wps如何删除幻灯片(手机wps如何删除空白页)

    手机wps如何删除幻灯片(手机wps如何删除空白页)

  • 抖音没有粉丝可以直播吗(抖音没有粉丝可以开播吗2023)

    抖音没有粉丝可以直播吗(抖音没有粉丝可以开播吗2023)

  • oppo reno听筒声音小(opporeno听筒音量小)

    oppo reno听筒声音小(opporeno听筒音量小)

  • xr不能用动态壁纸吗(xr不能用动态壁纸怎么办)

    xr不能用动态壁纸吗(xr不能用动态壁纸怎么办)

  • 小米有超级省电模式吗(小米超级省电模式闹钟还会响吗)

    小米有超级省电模式吗(小米超级省电模式闹钟还会响吗)

  • 小窝中安睡的欧亚红松鼠,苏格兰高地 (© Neil Anderson/Minden Pictures)(安个小窝)

    小窝中安睡的欧亚红松鼠,苏格兰高地 (© Neil Anderson/Minden Pictures)(安个小窝)

  • 织梦后台直接添加会员功能开发方法(织梦怎么建站)

    织梦后台直接添加会员功能开发方法(织梦怎么建站)

  • 出口退税的账怎么做
  • 费用计入管理费用与销售费用的区别
  • 新入职员工哪月交社保
  • 企业净利率多少算正常
  • 新准则金融资产科目名称
  • 资产处置收益是什么意思
  • 净现值率和现值指数之间的关系
  • 律师事务所的账务流程
  • 税收减免备案分录怎么写
  • 消费税申报流程税务实训平台
  • 免税货物开成含税率的怎么报税?
  • 买鼠标去哪买
  • 股东借款利息代扣代缴增值税是怎样算的?
  • 认缴制下实收资本印花税
  • 税务局代增值税普通发票流程
  • 收到发票,未付款,付款的时候需要把发票复印做附件吗
  • 给客户购买礼品怎么记账
  • 差旅费账务处理例子
  • 如何手机个人热点连电脑
  • php注册功能的实现
  • flash process
  • element ui el-table
  • 印花税哪里买
  • 房地产预缴所得税怎么算
  • html基础总结
  • yew 框架
  • 税控盘和金税盘的功能一样吗
  • web前端性能响应时间
  • js es6常用方法
  • overflow常见释义
  • python自动控制
  • linuxshel
  • dos命令怎么转到d盘
  • 预计负债初始计量的最佳估计数的确定是会计估计变更吗
  • 银行收到企业存款会计分录
  • 官方的问答
  • 公司法人和经理的区别
  • 车辆购置税如何在电子税务局缴纳
  • 归还股东借款要交税吗
  • 如何利用远期交易保值
  • 经营结余和事业结余
  • 以前年度少计成本的税务处理
  • 生产成本和营业成本的区别和联系
  • 汽车运输企业交什么税
  • 长期待摊费用包含的内容
  • 电商账务怎么做
  • 预提费用汇算清缴如何调整
  • 企业办理名称变更怎么办
  • 工人的工资占企业的比例
  • 费用多计提了怎么办
  • 2018年水利建设基金税率
  • 委托加工的成本如何核算
  • Windows如何自动关机
  • win7连接宽带
  • centos配置IP地址
  • 在windows xp
  • geom是什么文件
  • hpm是什么格式的文件
  • 微软官方屏蔽更新工具
  • 怎么判断进程是否存在
  • windows8用的人少
  • linux的虚拟终端有几个
  • windows 10运行
  • nodejs代码规范
  • android substrate
  • importem
  • 使用jquery操作dom
  • jquery选择器的基本语法
  • nodejs一键安装
  • nodejs实现文件下载
  • 查看shell脚本
  • jquery 使用
  • python编写代码的步骤
  • 详解Bootstrap四种图片样式
  • python设颜色代码
  • 税务局领取发票后怎么操作
  • 注册会计师和注册建造师哪个难考
  • 税务局三方协议变更
  • 法人实名采集必须去现场吗
  • 个人所得税app可以更改电话号码吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设