vue中子组件的methods中获取到props中的值方法


Posted in Javascript onAugust 27, 2018

父子组件通信

这个官网很清楚,也很简单,父组件中使用v-bind绑定传送,子组件使用props接收即可

例如:

父组件中

<template>
  <div>
    <head-top></head-top>
    <section class="data_section">
      <header class="chart-title">数据统计</header>
      <el-row :gutter="20" class="chart-head">
        <el-col :xs="24" :sm="12" :md="6" :lg="6"><div class="grid-content data-head blue-head">统计:</div></el-col>
        <el-col :xs="24" :sm="12" :md="6" :lg="6"><div class="grid-content data-head">销售数量 <span>{{number}}</span></div></el-col>
        <el-col :xs="24" :sm="12" :md="6" :lg="6"><div class="grid-content data-head">销售金额 <span>{{amount}}</span></div></el-col>
        <el-col :xs="24" :sm="12" :md="6" :lg="6"><div class="grid-content data-head">利润统计 <span>{{profits}}</span></div></el-col>
      </el-row>
    </section>
    <chart :chartData="chartData"></chart>
  </div>
</template>

<script>
  data(){
      return {
        number: null,
        amount: null,
        profits: null,
        chartData: [10,10,10]
      }
    },
</script>

子组件中

export default {
  props: ['chartData']
}

这种情况下,子组件的methods中想要取到props中的值,直接使用this.chartData即可

但是有写情况下,你的chartData里面的值并不是固定的,而是动态获取的,这种情况下,你会发现methods中是取不到你的chartData的,或者取到的一直是默认值

比如下面这个情况

父组件中

<script>
  data(){
      return {
        number: null,
        amount: null,
        profits: null,
        chartData: []
      }
    },
    mounted(){
      this.getStatistics();
    },
    methods: {
      //获取统计数据
      getStatistics(){
        console.log('获取统计数据')
        axios.post(api,{

        }).then((res) => {
          this.number = res.data.domain.list[0].number;
          this.amount = res.data.domain.list[0].amount;
          this.profits = res.data.domain.list[0].profits;
          this.chartData = [this.number,this.amount,this.profits];
        }).catch((err) => {
          console.log(err);
        })
      },
    },
</script>

此时子组件的methods中使用this.chartData会发现是不存在的(因为为空了)

这情况我是使用watch处理

解决方法如下:

使用watch

props: ['chartData'],
    data(){
      return {
        cData: []
      }
    },
    watch: {
      chartData: function(newVal,oldVal){
        this.cData = newVal; //newVal即是chartData
        this.drawChart();
      }
    },

监听chartData的值,当它由空转变时就会触发,这时候就能取到了,拿到值后要做的处理方法也需要在watch里面执行

以上这篇vue中子组件的methods中获取到props中的值方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery购物车实时结算特效实现思路
Sep 23 Javascript
JS随机漂浮广告代码具体实例
Nov 19 Javascript
checkbox全选所涉及到的知识点介绍
Dec 31 Javascript
AngularJS初始化静态模板详解
Jan 14 Javascript
浅谈Node.js:fs文件系统模块
Dec 08 Javascript
JS变量及其作用域
Mar 29 Javascript
JS实现动态添加DOM节点和事件的方法示例
Apr 28 Javascript
Node.js 8 中的 util.promisify的详解
Jun 12 Javascript
JavaScript实现树的遍历算法示例【广度优先与深度优先】
Oct 26 Javascript
Vue官方推荐AJAX组件axios.js使用方法详解与API
Oct 09 Javascript
如何搭建一个完整的Vue3.0+ts的项目步骤
Oct 18 Javascript
vant-ui AddressEdit地址编辑和van-area的用法说明
Nov 03 Javascript
最适应的vue.js的form提交涉及多种插件【推荐】
Aug 27 #Javascript
vue里面v-bind和Props 利用props绑定动态数据的方法
Aug 27 #Javascript
vue.js中toast用法及使用toast弹框的实例代码
Aug 27 #Javascript
对Vue- 动态元素属性及v-bind和v-model的区别详解
Aug 27 #Javascript
VUE-Table上绑定Input通过render实现双向绑定数据的示例
Aug 27 #Javascript
vue监听input标签的value值方法
Aug 27 #Javascript
vue打包使用Nginx代理解决跨域问题
Aug 27 #Javascript
You might like
让ThinkPHP支持大小写url地址访问的方法
2014/10/31 PHP
深入理解PHP 数组之count 函数
2016/06/13 PHP
php 获取xml接口数据的处理方法
2018/05/31 PHP
jQuery 页面载入进度条实现代码
2009/02/08 Javascript
Javascript中获取出错代码所在文件及行数的代码
2010/09/23 Javascript
poshytip 基于jquery的 插件 主要用于显示微博人的图像和鼠标提示等
2012/10/12 Javascript
JavaScript制作的可折叠弹出式菜单示例
2014/04/04 Javascript
javascript实现3D切换焦点图
2015/10/16 Javascript
javascript实现label标签跳出循环操作
2016/03/06 Javascript
jQuery代码实现图片墙自动+手动淡入淡出切换效果
2016/05/09 Javascript
js+html5实现canvas绘制椭圆形图案的方法
2016/05/21 Javascript
浅析Javascript中bind()方法的使用与实现
2016/05/30 Javascript
jQuery四种选择器使用及示例
2016/06/05 Javascript
利用Angularjs和bootstrap实现购物车功能
2016/08/31 Javascript
javascript循环链表之约瑟夫环的实现方法
2017/01/16 Javascript
vue项目搭建以及全家桶的使用详细教程(小结)
2018/12/19 Javascript
jQuery实现带3D切割效果的轮播图功能示例【附源码下载】
2019/04/04 jQuery
「中高级前端面试」JavaScript手写代码无敌秘籍(推荐)
2019/04/08 Javascript
重学JS 系列:聊聊继承(推荐)
2019/04/11 Javascript
vue中npm包全局安装和局部安装过程
2019/09/03 Javascript
Python的Twisted框架上手前所必须了解的异步编程思想
2016/05/25 Python
Python中死锁的形成示例及死锁情况的防止
2016/06/14 Python
python中对数据进行各种排序的方法
2019/07/02 Python
用Python匹配HTML tag的时候,<.*>和<.*?>有什么区别
2012/11/04 面试题
打架检讨书100字
2014/01/19 职场文书
高一物理教学反思
2014/01/24 职场文书
《找不到快乐的波斯猫》教学反思
2014/02/24 职场文书
大学生自我鉴定书
2014/03/24 职场文书
2014年三万活动总结
2014/04/26 职场文书
关于祖国的演讲稿
2014/05/04 职场文书
优质护理服务演讲稿
2014/05/07 职场文书
李强优秀员工观后感
2015/06/16 职场文书
葬礼主持词
2015/07/02 职场文书
大学军训通讯稿
2015/07/18 职场文书
《中国古代诗歌散文欣赏》高中语文教材
2019/08/20 职场文书
Redis实现一个账号只能登录一个设备
2022/04/19 Redis