props传值问题

父组件和子组件同时展现

同步任务无需添加额外的代码,正常写,而异步任务需要添加下面的解决方案,因为异步任务需要等待响应才能进行赋值。

父组件:

html 复制代码
<div>
	<UploadFile ref="child" :data="tableData"></UploadFile>
</div>
javascript 复制代码
created () {
  this.init();
},
methods: {
  showdialog () {
    this.dialogFormVisible = true;
  },
  init () {
    this.$axios({
      url: `/proxy_version/renew/getList`,
      method: 'post',
      data: {
        pageNo: 1,
        pageSize: 100
      },
      success: (result) => {
        this.tableData = result.data.list[0];
        this.tableData.versionType = "1";
        console.log("this.tableData", this.tableData);
      }
    });
  },
}

通过props父组件在created函数中初始化子组件的数据

子组件:

javascript 复制代码
 props: ['data'],
 data () {
   return {
     formdata: this.data,
     versionNum: this.data.versionNumber,
   }
 },
 // 或者
created () {
	this.formdata = this.data;
	this.versionNum = this.data.versionNumber;
	console.log("data", this.data);
},

子组件在created中进行接收或者在data中进行更改,created和data都是页面在渲染时才会调用,后面就不会再去调用created和data中进行赋值。

按上面的方法会出现versionNumber等属性undefined,这是因为在父组件调用接口传递数据给子组件时,接口响应显然是异步的。这会导致无论你在父组件哪个钩子发请求,在子组件哪个钩子接收数据,都是取不到的。

解决方法:

1.加上一个v-if进行判断

javascript 复制代码
<div>
	<UploadFile ref="child" :data="tableData" v-if="tableData"></UploadFile>
</div>

tableData要设置为null或者undefined,或者v-if更改条件,设置为null或defined,则在赋值时不可以this.tableData.versionType = "1";否则报错。在渲染子组件的时候加上一个条件,当有数据的时候在去渲染子组件。这样就会形成天然的阻塞。在父组件的created中的请求返回数据后,才会执行子组件的created,mounted。最后执行父组件的mounted。

2.使用watch进行监听

javascript 复制代码
watch: {
   data: {
     deep: true,
     handler: function (newVal, oldVal) {
       this.$nextTick(() => {
         this.formdata = newVal
         this.versionNum = newVal.versionNumber;
       })
     }
   }
 },

在子组件中添加watch监听, 父组件获取到值得时候, 就会触发watch监听, 从而实现重新渲染子组件。

父组件点击之后显示子组件

props:

同步任务:

父组件:

html 复制代码
<div>
    <el-button @click="showdialog">点击</el-button>
    <div>
      <el-dialog width="50%" title="对象信息" :visible.sync="dialogFormVisible">
        <UploadFile ref="child" :data="tableData"></UploadFile>
      </el-dialog>
    </div>
  </div>
javascript 复制代码
 showdialog () {
      this.dialogFormVisible = true;
      this.tableData.versionType = "1";
      this.tableData.versionNumber = '1.0.0';
      console.log(this.tableData);
    },

子组件:

javascript 复制代码
 props: ['data'],
  data () {
    return {
      formdata: this.data,
      versionNum: this.data.versionNumber,
    }
  },
  //或者
created () {
	this.formdata = this.data;
	this.versionNum = this.data.versionNumber;
},

点击事件中为同步代码则没有任何问题,可以显示数据。

异步任务

但如果是异步任务,则无法显示数据,因为异步任务返回结果时,子组件的created和data都已经初始化完成。

解决方案1:

父组件:

html 复制代码
<div>
    <el-button @click="showdialog">点击</el-button>
    <div>
      <el-dialog width="50%" title="对象信息" :visible.sync="dialogFormVisible">
        <UploadFile ref="child" :data="tableData"></UploadFile>
      </el-dialog>
    </div>
  </div>
javascript 复制代码
showdialog () {
	this.dialogFormVisible = true;
	this.$axios({
		url: `/proxy_version/renew/getList`,
		method: 'post',
		data: {
			pageNo: 1,
			pageSize: 100
		},
		success: (result) => {
			this.tableData = result.data.list[0];
			this.tableData.versionType = "1";
			console.log("this.tableData", this.tableData);
	}
});

子组件:

javascript 复制代码
props: ['data'],
 data () {
   return {
     formdata: {},
     versionNum: null,
   }
 },
 
watch: {
    data: {
      deep: true,
      handler: function (newVal, oldVal) {
        this.$nextTick(() => {
          this.formdata = newVal
          this.versionNum = newVal.versionNumber;
          console.log(this.formdata);
        })
      }
    }
  },

在子组件加入watch函数进行监测。

解决方案2:

父组件:

html 复制代码
  <div>
    <el-button @click="showdialog">点击</el-button>
    <div>
      <el-dialog width="50%" title="对象信息" :visible.sync="dialogFormVisible">
        <UploadFile ref="child" :data="tableData" v-if="tableData"></UploadFile>
      </el-dialog>
    </div>
  </div>
 //  父组件点击方法不变,正常写

加上v-if进行判断tableData有没有值,有才渲染子组件

子组件可以在created函数中进行赋值也可以在data中进行赋值。

相关推荐
cloues break.6 分钟前
C++进阶----多态
开发语言·c++
我不会编程55513 分钟前
Python Cookbook-6.10 保留对被绑定方法的引用且支持垃圾回收
开发语言·python
低代码布道师21 分钟前
第二部分:网页的妆容 —— CSS(下)
前端·css
道剑剑非道27 分钟前
QT开发技术【qcustomplot 曲线与鼠标十字功能】
开发语言·qt·计算机外设
一纸忘忧27 分钟前
成立一周年!开源的本土化中文文档知识库
前端·javascript·github
刘婉晴41 分钟前
【环境配置】Mac电脑安装运行R语言教程 2025年
开发语言·macos·r语言
Despacito0o41 分钟前
C++核心编程:类与对象全面解析
开发语言·c++
Tiger Z42 分钟前
R 语言科研绘图第 43 期 --- 桑基图-冲击
开发语言·r语言·贴图
涵信1 小时前
第九节:性能优化高频题-首屏加载优化策略
前端·vue.js·性能优化
前端小巷子1 小时前
CSS单位完全指南
前端·css