vue3踩坑笔记

今年开始抛弃vue2了,正式使用vue3。虽然知道有坑,但是没想到坑是这样的。
随时补充吧

dev不报错,build过不去的事

  1. ctx.$emitdefineEmits的故事

现象:在<script setup></script>中使用ctx.$emit后,dev环境下运行正常。build后运行报错。
解决办法:改为使用defineEmits初始化事件

// 初始事件
const emits = defineEmits(['eventname1','name2']);
// 触发
emits('eventname1',params);
  1. <script setup></script>中的globalProperties调用

现象:在<script setup></script>中使用ctx.自定义全局后,dev环境下运行正常。build后运行报错。
解决办法:不在ctx下调用,而是

const {
    appContext: {config: {globalProperties: global}},
} = getCurrentInstance();
// 引用
global.xxx
  1. 关于dom绑定变量时,变量和相关函数的定义

现象:我犯的错误是这样的,在export default{}data定义的变量A,methods中定义了修改变量的函数F,然后在setup中调用F来修改变量A,dev环境下都正常,build的时候报错,找不到A变量
解决办法:在涉及绑定变量读写逻辑时,两个选择,定义和逻辑都在data+methods里写,或者在setup中定义变量和函数,尽量不要混用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值