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

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条)

报告相同问题?

悬赏问题

  • ¥20 易康econgnition精度验证
  • ¥15 线程问题判断多次进入
  • ¥15 msix packaging tool打包问题
  • ¥28 微信小程序开发页面布局没问题,真机调试的时候页面布局就乱了
  • ¥15 python的qt5界面
  • ¥15 无线电能传输系统MATLAB仿真问题
  • ¥50 如何用脚本实现输入法的热键设置
  • ¥20 我想使用一些网络协议或者部分协议也行,主要想实现类似于traceroute的一定步长内的路由拓扑功能
  • ¥30 深度学习,前后端连接
  • ¥15 孟德尔随机化结果不一致