曾经对你的执着 2021-01-30 17:13 采纳率: 50%
浏览 352
已采纳

Vue中methods使用data的疑问

代码是这样的,在data中定义了一个名为AnimatorChoices的属性并设置为false

data() {
      return {
        AnimatorChoices: false
      }
},

在methods中打印

methods: {
      upOptions() {
        console.log(this.AnimatorChoices)  //这里输出false
        onscroll = function () {
          let height = document.body.scrollTop || document.documentElement.scrollTop;
          if (height > 80) {
            console.log(this.AnimatorChoices)  //这里输出为什么为undefined
            this.AnimatorChoices = true;  
            console.log(this.AnimatorChoices)
          }
        }
      }
    },

方法在created声明周期函数中调用

created() {
      this.upOptions()
    }

为什么会输出undefined

 

  • 写回答

3条回答 默认 最新

  • PythonJavaC++go 2021-01-30 17:30
    关注

    你在upOptions方法里面又建了一个方法onscroll, 此时onscroll的this不是当前vue对象。

    简单理解就是method的中的单层方法才可以直接调用data。

    解决方法一:使用回调函数

    解决方法二:that=this

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?