Web_Design 板


LINE

如题,写Vue时子元件要操作父元件的function会使用emit的方式 但由於过去都是在写React,所以在练习Vue的时候自然而然的 就把父元件的function当作prop传送到子元件中 子元件再直接拿prop的参数来当作function执行 一切也都没什麽问题 於是心中就有疑问了,既然如此 我把父元件的function当作prop传下去执行 跟使用emit的方式,有什麽差异吗? Example: (父元件) <Child :handleClick="handleClick" /> (子元件) <button @click="handleClick()">click</button> --



※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 115.43.135.34 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Web_Design/M.1679750183.A.BC5.html
1F:→ ck574b027: 维护上的差别。自己也会宣告函数,两种都 @event="f()" 03/25 23:04
2F:→ ck574b027: 这样呼叫,你要怎麽一眼看出他的来源 03/25 23:05
3F:→ ssccg: 差在跟Vue.js的convention不同,别人可能不习惯这种用法 03/25 23:11
4F:→ ssccg: Vue.js的官方建议就是往下用props,往上用event 03/25 23:17
5F:→ ssccg: 另外可能有比较方便的可能是event有内建一些modifier 03/25 23:21
6F:→ ssccg: 至於一楼说的那都是命名问题吧,emit跟props一样自订命名, 03/25 23:27
7F:推 shter: 传进去跟不传进去应用的场合不同 03/25 23:27
8F:→ ssccg: 一样设自订命名的function,用typescript一样能宣告type 03/25 23:30
9F:→ ssccg: 反而是emit还能写对handler function传入值的validation 03/25 23:31
10F:→ ssccg: (虽然emit不宣告也能直接$emit,props一定要宣告,让有些人 03/25 23:32
11F:→ ssccg: 误会props比较严谨) 03/25 23:32
12F:推 shter: 如果父子组件都是你自己写的这样搞当然没关系 03/25 23:44
13F:→ shter: 但很多时候会有共用组件、组件库,跨专案在使用单独打包的 03/25 23:44
14F:→ shter: 这样设计 :传参数 @收事件 的作法比较单纯,就是接口的型别 03/25 23:45
15F:→ shter: 掌握好就可以了,因为对应用层来说都是收事件参数而已 03/25 23:46
16F:→ shter: 如果要传 Function 进去那使用方式说明上就会变得复杂 03/25 23:47
17F:→ shter: Vue 把每一区都设计的很单纯,但也没阻止你复杂的使用它 03/25 23:49
18F:→ ssccg: 还有一点是直接呼叫props传进来的function跟用$emit不同, 03/26 00:41
19F:→ ssccg: 不会经过Vue.js的一些检查,例如子元件unmounted後$emit就 03/26 00:42
20F:→ ssccg: 会被忽略,而function如果丢去非同步执行的callback那可能 03/26 00:44
21F:→ ssccg: 连父元件都unmounted了照样执行下去 03/26 00:44
22F:→ ck574b027: 一楼的意思是 "$emit()" 跟 "f()" 可以帮助分辨handler 03/26 23:52
23F:→ ck574b027: 来源,用props就跟local函数搞混了 03/26 23:53
24F:推 ck574b027: 19F差别也太重要了吧,根本是会引起灵异事件的程度 03/27 00:09







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:BabyMother站内搜寻

TOP