当前位置:首页 > 前端 > 正文内容

关于vue2中data值为不定长对象动态更改页面不生效的终极解决方案

Z先生3年前 (2021-12-14)前端709

问题描述

子组件,定义了空data值,通过参数传递过来,通过watch修改,页面不更新,日志输出确定内容已经改过来。

已经测试方案

找了很多方案,this.$forceUpdate()this.$nextTick().then(() =>{})setTimeout深度克隆this.$set()均无效

终极解决方案

这里只展示脚本部分

<script>
  export default {
    components: {},
    props: {
      show: {
        type: Boolean,
        default: false,
      },
      data: {
        type: Object,
        default: null,
      },
    },
    data() {
      return {
        formData: {},
        rowData: {},
        drawerShow: false,
        confirmLoading: false,
      }
    },
    computed: {
      tmpData: {
        get: function () {
          let configData = this.data.config
          let fromData = { ident: this.data.ident }
          fromData = Object.assign({}, fromData, configData)
          return fromData
        },
        set: function (value) {
          this.fromData = value
        },
      },
    },
    watch: {
      tmpData(val) {
        this.formData = val
      },
      data(val) {
        this.rowData = val
      },
      show(val) {
        this.drawerShow = val
      },
    },
    beforeCreate() {
    },
    created() {},
    mounted() {
    },
    methods: {
      drawerClose() {
          //父组件要通过 :show.sync调用才生效
        this.$emit('update:show', false) //自定义事件会告诉父组件将父组件的 show值改为false,并传回给子组件。
      },
      clickSubmit() {

      }

      clickCancel() {
        this.drawerClose()
        this.$emit('cancel')
      },
    },
  }
</script>

代码解析:页面上用到的是formData,直接通过watch中的data监听修改formData无效,所以在computed中,加入了tmpData作为中间值,然后在watch中监听tmpData的变化,将变化值交给formData,然后就没问题了。

分享给朋友:

相关文章

H5模拟微信菜单下拉菜单

H5模拟微信菜单下拉菜单

核心HTML代码:核心点:外层类“submenu-warp”子菜单类:“submenu”<div data-href="#mainurl" class=&...

【原创】api接口模拟器(NodeJS版)

最近遇到一个项目,内网的APP,后端数据和前段开发属于异地,没法直接做接口数据测试。因此用NodeJs简单写了个API模拟器,只要将响应的数据放在对应目录下json.json文件中即可。请求地址全静态...

npm 更新模块

npm update只能按照package.json中标注的版本号进行更新,升级后不会修改package.json中的版本号,需要自己手动修改,比较麻烦。npm-check-updates 升级插件升...

uniapp开发小程序,小程序二维传参与H5、分享页面参数兼容的处理方案。

首先小程序获取二维码接口有三个,2个限制数量,一个不限制数量,但是限制生成频率(5000次/分钟)和参数长度(32位),我使用的是不限数量的接口:getUnlimited,传递的参数为:invite=...

微信html链接小程序原始写法(暂未测试)

微信html链接小程序原始写法(暂未测试)

无意间发现了微信的这个链接,这几天比较忙,暂时还没有测试,等空了再测试一下。<a class="weapp_text_link"   &nbs...

js中获取当前url路径

网上转的,用的时候整理// 返回 web 主机的域名,如:http://127.0.0.1:8080/testdemo/test.html?id=1&name=t...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。