Vue使用问题记录(持续更新…)

1、数组非响应式

  • 直接修改数组的长度 比如 this.list.lenght = 10;

  • 利用索引直接设置数组的某一项 比如 this.list[2]= {aa:‘aa’}

通过以上两种方式修改,页面视图无法刷新。
 
原因猜测:

    vue源码,通过Object.defineProperty()对对象属性的读和写分别使用get()和set()进行拦截,每当该属性进行读或写操作的时候就会触发get()和set(),使得一个对象转化成可观测对象。而数组通过将拦截挂载到数组实例与Array.prototype之间,这样通过数组原生方法操作数据,就能侦测到变化。 这里通过array.length = 0修改, 而不是通过数组原生方法修改,所以侦测不到。

解决方案:

1、通过数组原生方法splice,可以实现增删改查 。(如:splice、 push 、pop、shirt、unshirt…)
2、通过Vue内部Vue.set() 实现响应式。

2、 路由守卫无法获取到this实例

  • 在beforeRouteEnter时,页面还没有渲染,无法获取this实例。

在这里插入图片描述

  • 报错:

在这里插入图片描述

  • 解决方案:
        通过next回调来访问实例。确认导航后,将调用回调,并将组件实例作为参数传递给回调:
    在这里插入图片描述
    注意:beforeRouteEnter调用在mounted之前,next 回调在mounted之后
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hui-1018

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值