qxy1547722058 2023-01-21 10:30 采纳率: 50%
浏览 48
已结题

VUE3,如何在外部修改data里面的对象?

VUE3,如何在外部修改data里面的对象?

var myvue = {
    data() {
        return {
            test: {}
        }
    },
    created() {
        testfunction(this);
    }
}
function testfunction(obj) {
    //想修改test,vue2的set方法不得行
    obj.test.myname='123';
    console.log(obj.test.myname);
}
var vm = Vue.createApp(myvue)
    .mount('#app')


  • 写回答

2条回答 默认 最新

  • 小蓝阿姨 2023-01-22 14:19
    关注

    效果图

    img


    代码如下,如果你修改的是data,直接把data传过去即可,因为对象是纯在一个拷贝问题的,所以可以直接把data传过去。

    // 在外部修改data
    const mTest = (data) => {
      data.test.myname = '外部修改的data'
    }
    
    const { createApp } = Vue
    const mVueOptions = {
      data() {
        return {
          test: {}
        }
      },
    
      mounted() {
        mTest(this.$data)
      }
    }
    createApp(mVueOptions).mount('#app')
    

    如有帮助请采纳

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

报告相同问题?

问题事件

  • 系统已结题 1月30日
  • 已采纳回答 1月22日
  • 修改了问题 1月21日
  • 创建了问题 1月21日