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

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日

悬赏问题

  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line
  • ¥500 火焰左右视图、视差(基于双目相机)