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中进行赋值。

相关推荐
@解忧杂货铺39 分钟前
前端vue如何实现数字框中通过鼠标滚轮上下滚动增减数字
前端·javascript·vue.js
数据小爬虫@40 分钟前
Java爬虫实战:深度解析Lazada商品详情
java·开发语言
songroom43 分钟前
Rust: offset祼指针操作
开发语言·算法·rust
code04号1 小时前
C++练习:图论的两种遍历方式
开发语言·c++·图论
煤泥做不到的!2 小时前
挑战一个月基本掌握C++(第十一天)进阶文件,异常处理,动态内存
开发语言·c++
F-2H2 小时前
C语言:指针4(常量指针和指针常量及动态内存分配)
java·linux·c语言·开发语言·前端·c++
gqkmiss3 小时前
Chrome 浏览器插件获取网页 iframe 中的 window 对象
前端·chrome·iframe·postmessage·chrome 插件
bryant_meng3 小时前
【python】OpenCV—Image Moments
开发语言·python·opencv·moments·图片矩
若亦_Royi4 小时前
C++ 的大括号的用法合集
开发语言·c++
资源补给站5 小时前
大恒相机开发(2)—Python软触发调用采集图像
开发语言·python·数码相机