Computed property was assigned to but it has no setter.

今天有一个很奇怪的bug,报错的原因我们可以看的很清楚,计算属性没有设置setter
在这里插入图片描述
这是计算属性源代码,计算属性有getter和setter,默认只有getter,需要时可以设置setter

 computed:{
    
    
    isActive(){
    
    
      return this.$route.path.indexOf(this.path) !== -1
    }
  },

虽然效果仍然可以实现,但是就是每次用该数据都会报错,看了vue官方文档
在这里插入图片描述
官方演示也是不带setter的,为啥我不设置setter就要报错呢?
最后修改方案:

computed:{
    
    
    isActive:{
    
    
      get(){
    
    
      return this.$route.path.indexOf(this.path) !== -1
      },
      set(val){
    
    }
    }
  },

猜你喜欢

转载自blog.csdn.net/d1063270962/article/details/113761889