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 相关文章推荐
Webkit的跨域安全问题说明
Sep 13 Javascript
JS随机漂浮广告代码具体实例
Nov 19 Javascript
jquery ajax传递中文参数乱码问题及解决方法说明
Feb 07 Javascript
JS获取地址栏参数的几种方法小结
Feb 28 Javascript
js实现图片旋转的三种方法
Apr 10 Javascript
JQ技术实现注册页面带有校验密码强度
Jul 27 Javascript
JS+CSS实现简易的滑动门效果代码
Sep 24 Javascript
超详细的JS弹出窗口代码大全
Apr 18 Javascript
微信小程序  生命周期详解
Oct 27 Javascript
详解Vue.js v-for不支持IE9的解决方法
Dec 29 Javascript
微信小程序实现渐入渐出动画效果
Jun 13 Javascript
vue使用微信扫一扫功能的实现代码
Apr 11 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
IIS6的PHP最佳配置方法
2007/03/19 PHP
动易数据转成dedecms的php程序
2007/04/07 PHP
ecshop 批量上传(加入自定义属性)
2012/03/20 PHP
php集成套件服务器xampp安装使用教程(适合第一次玩PHP的新手)
2015/06/03 PHP
PHP框架Laravel学习心得体会
2015/10/28 PHP
PHP面向对象程序设计组合模式与装饰模式详解
2016/12/02 PHP
Laravel框架表单验证操作实例分析
2019/09/30 PHP
javascript 放大镜效果js组件 qsoft.PopBigImage.v0.35 加入了chrome支持
2009/04/07 Javascript
javascript中数组的concat()方法使用介绍
2013/12/18 Javascript
js实现字符串的16进制编码不加密
2014/04/25 Javascript
javascript面向对象快速入门实例
2015/01/13 Javascript
学习Bootstrap滚动监听 附调用方法
2016/07/02 Javascript
AngularJS入门教程之AngularJS 模板
2016/08/18 Javascript
微信小程序scroll-view横向滑动嵌套for循环的示例代码
2018/09/20 Javascript
详解puppeteer使用代理
2018/12/27 Javascript
小程序二次贝塞尔曲线实现购物车商品曲线飞入效果
2019/01/07 Javascript
超详细动手搭建一个VuePress 站点及开启PWA与自动部署的方法
2019/01/27 Javascript
Python使用scrapy采集数据过程中放回下载过大页面的方法
2015/04/08 Python
Python实现比较两个列表(list)范围
2015/06/12 Python
Python微信库:itchat的用法详解
2017/08/14 Python
Python的条件锁与事件共享详解
2019/09/12 Python
TensorFlow2.X结合OpenCV 实现手势识别功能
2020/04/08 Python
python导入库的具体方法
2020/06/18 Python
学python需要去培训机构吗
2020/07/01 Python
Python 多进程原理及实现
2020/12/21 Python
标记环介质访问控制协议
2016/03/27 面试题
电子信息专业学生自荐信
2013/11/09 职场文书
文秘大学生求职信
2014/02/25 职场文书
合作意向书范本
2014/03/31 职场文书
学历公证委托书
2014/04/09 职场文书
闪闪红星观后感
2015/06/08 职场文书
七年级思品教学反思
2016/02/20 职场文书
MySQL优化之如何写出高质量sql语句
2021/05/17 MySQL
Vue实现动态查询规则生成组件
2021/05/27 Vue.js
浅谈MySQL表空间回收的正确姿势
2021/10/05 MySQL
磁贴还没死, 微软Win11可修改注册表找回Win10开始菜单
2021/11/21 数码科技