vue watch深度监听一个对象时,怎么把监听到的newvalue赋值给data里的变量?

发布于 2022-09-07 08:36:10 字数 653 浏览 32 评论 0

pageData是一个对象,从父辈传过来的,我在子组件里面通过props接收到pageData,想要用watch监听到pageData对象里的属性有变化,然后赋值给newpageData。

但是普通的监听pageData,根本都不会触发。改成深度监听之后。 console.log(newval)是能监听到pageData的最新值的。然后我想要赋值给 this.newpageData就报错了。

**Error in callback for watcher 'pageData'
newpageData is not defined**

请问有什么办法可以解决?

props:['pageData'],
data(){
    return{
       newpageData:null
    }
},
  watch:{
       pageData:{
                handler: function (newval, oldVal) {
                    console.log(newval)
                    this.newpageData=newval;
                },
                deep: true
            }
        }    

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

[浮城] 2022-09-14 08:36:10

检查一下this指向

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文