亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

VUE父組件異步獲取數(shù)據(jù),子組件接收的值為空的問題

 更新時間:2023年10月24日 15:31:26   作者:修復(fù)BUG中  
這篇文章主要介紹了VUE父組件異步獲取數(shù)據(jù),子組件接收的值為空的問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

在vue中引用Echarts圖表,動態(tài)渲染數(shù)據(jù)時一直不展示數(shù)據(jù)。

父組件異步請求獲取數(shù)據(jù)傳給子組件,子組件接收的打印的真實的值卻為初始值,如下所示

  • 父組件

  • 子組件

原因的話:

加載渲染的時候,請求是一個異步的操作,子組件在拿到數(shù)據(jù)前就渲染了,子組件沒有監(jiān)控到值得變化

父子組件加載渲染過程

父beforeCreate->父created->父beforeMount->子beforeCreate->子created->子beforeMount->子mounted->父mounted

昨天晚上遇到這個問題,在網(wǎng)上找了是下面三個方法:

  • 在子組件用watch監(jiān)控父組件傳遞過來值得變化,設(shè)置deep:true【deep官方定義:為了發(fā)現(xiàn)對象內(nèi)部值的變化,可以在選項參數(shù)中指定 deep: true。注意監(jiān)聽數(shù)組的變更不需要這么做?!?/li>
  • 在父組件使用v-if,當(dāng)請求結(jié)束之后,改變v-if內(nèi)變量的值,加載子組件
  • 使用vuex全局狀態(tài)管理,這個沒嘗試

上面三種方法的話:

  • 第一種是最簡潔明了的,但是昨天晚上第一種方法一直不成功,可能是語法寫錯了,今天早上上班試了一下才成功;
  • 因為我們做的是數(shù)據(jù)展示,所以第二種就不適合我們的需求;
  • 第三種的話我就沒試,網(wǎng)上的解決流程感覺太麻煩了;

這樣的話,其實昨天就沒解決這個問題,下班回去的時候換了一個思路想了這個問題,這個原因就是父組件異步請求沒有更新子組件的數(shù)據(jù)值,其實我們可以手動的更新子組件的值,在父組件異步請求拿到數(shù)據(jù)時,在成功回調(diào)賦值的時候,手動的調(diào)用子組件的方法,并把數(shù)據(jù)當(dāng)成參數(shù)傳遞過去,子組件的處理就是在該方法內(nèi)手動的刷新對象的,今天早上上班按照該思路,發(fā)現(xiàn)可以解決這個問題。

下面就介紹一下vue父組件異步獲取數(shù)據(jù),子組件接收的值為空三種解決方法:

1.父組件異步獲取數(shù)據(jù),調(diào)用子組件方法重新賦值 【第二種方法不行,推薦使用該方法】

  • 父組件
<template>
  <div class="index">
  	//設(shè)置ref的值,下面調(diào)用
    <ChartBasicLine :chartObj="chartRegUser" :ref="chartRegUser.type" />
  </div>
</template>

<script>
import { getStatUser } from '@/api/data'
import ChartBasicLine from '@/components/Chart/ChartBasicLine'

export default {
  components: {
    ChartBasicLine
  },
  data() {
    return {
      chartRegUser: {
        num: 0,
        percent: '0.00%',
        status: 0,
        type: 'reg_user',
        tips: '新增用戶',
        title: '新增用戶(NU)',
        link: '',
        isShow: false,
        xData: [],
        yData: []
      }
    }
  },
  created() {
    this.getStatUser()
  },
  methods: {
    getStatUser() {
      const _this = this
      
      // 異步請求獲取數(shù)據(jù)
      getStatUser().then(res => {
        if (res.code === 0) {

		  // 賦值
          _this.$set(_this.chartRegUser, 'xData', res.data['x_data'])
          _this.$set(_this.chartRegUser, 'yData', res.data['y_data'])
		  
		  // 這里是調(diào)用子組件的refresh的方法
          _this.$refs[_this.chartRegUser.type].refresh(res.data)
        }
      })
    }
  }
}
</script>
  • 子組件
<template>
  <div class="ChartBasicLine">
    <div
      :ref="chartObj.type"
      class="chart_show"
    />
  </div>
</template>

<script>
export default {
  name: 'ChartBasicLine',
  props: {
    chartObj: {
      type: Object
    }
  },
  data() {
    return {
      option: {
        tooltip: {
          trigger: 'axis'
        },
        grid: {
          top: '22px',
          left: '40px',
          right: '30px'
        },
        xAxis: {
          type: 'category'
        },
        yAxis: {
          type: 'value'
        },
        series: [{
          type: 'line'
        }]
      },
      myChart: {}
    }
  },
  mounted() {
    this.showChart()
  },
  methods: {
    showChart() {
      this.myChart = this.$echarts.init(this.$refs[this.chartObj.type])
      this.option.xAxis['data'] = this.chartObj.xData
      this.option.series[0]['data'] = this.chartObj.yData
      this.myChart.setOption(this.option)
    },
    /**
     * 父組件給圖表信息重新賦值,并重新刷新圖表
     */
    refresh(data) {
      this.option.xAxis['data'] = data['x_data']
      this.option.series[0]['data'] = data['y_data']
      this.myChart.setOption(this.option)
    }
  }
}
</script>
<style>
  .ChartBasicLine .el-input {
    margin-right: 0 !important;
  }
</style>

2.子組件內(nèi)使用watch監(jiān)控對象值變化時重新賦值【推薦】

  • 子組件
<template>
  <div class="ChartBasicLine">
    <div
      :ref="chartObj.type"
      class="chart_show"
    />
  </div>
</template>

<script>
export default {
  name: 'ChartBasicLine',
  props: {
    chartObj: {
      type: Object
    }
  },
  data() {
    return {
      option: {
        tooltip: {
          trigger: 'axis'
        },
        grid: {
          top: '22px',
          left: '40px',
          right: '30px'
        },
        xAxis: {
          type: 'category'
        },
        yAxis: {
          type: 'value'
        },
        series: [{
          type: 'line'
        }]
      },
      myChart: {}
    }
  },
  watch: {
    chartObj: { // 監(jiān)控該變量,重新賦值并刷新圖表
      handler(newVal, oldVal) {
        this.chartObj = newVal
        this.showChart()
      },
      deep: true // 必須設(shè)置
    }
  },
  mounted() {
    this.showChart()
  },
  methods: {
    showChart() {
      this.myChart = this.$echarts.init(this.$refs[this.chartObj.type])
      this.option.xAxis['data'] = this.chartObj.xData
      this.option.series[0]['data'] = this.chartObj.yData
      this.myChart.setOption(this.option)
    }
  }
}
</script>

3.父組件內(nèi)使用v-if渲染子組件【不推薦】

  • 父組件
<template>
  <div class="index">
  	// 通過v-if來控制子組件顯示
    <ChartBasicLine v-if="isShow" />
  </div>
</template>

<script>
import { getStatUser } from '@/api/data'
import ChartBasicLine from '@/components/Chart/ChartBasicLine'

export default {
  components: {
    ChartBasicLine
  },
  data() {
    return {
      chartRegUser: {
        num: 0,
        percent: '0.00%',
        status: 0,
        type: 'reg_user',
        tips: '新增用戶',
        title: '新增用戶(NU)',
        link: '',
        isShow: false,
        xData: [],
        yData: []
      },
      isShow: false // 控制子組件是否展示
    }
  },
  created() {
    this.getStatUser()
  },
  methods: {
    getStatUser() {
      const _this = this
      getStatUser().then(res => {
        if (res.code === 0) {
          _this.$set(_this.chartRegUser, 'xData', res.data['x_data'])
          _this.$set(_this.chartRegUser, 'yData', res.data['y_data'])
          
          // 異步請求獲取數(shù)據(jù),展示子組件
          _this.isShow = true
        }
      })
    }
  }
}
</script>

VUE中數(shù)組賦空值注意事項

在js或者Vue中,給數(shù)組賦空值不可以直接賦空值,例如:

var list = {a:'12',b:'34'};// 創(chuàng)建一個數(shù)組

list = [];// 數(shù)組賦空值

否則會在再次賦值的時候報錯

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 分享一個精簡的vue.js 圖片lazyload插件實例

    分享一個精簡的vue.js 圖片lazyload插件實例

    本篇文章主要介紹了分享一個精簡的vue.js 圖片lazyload插件實例。非常具有實用價值,需要的朋友可以參考下。
    2017-03-03
  • 深入淺出vue圖片路徑的實現(xiàn)

    深入淺出vue圖片路徑的實現(xiàn)

    這篇文章主要介紹了深入淺出vue圖片路徑的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • vue2.0.js的多級聯(lián)動選擇器實現(xiàn)方法

    vue2.0.js的多級聯(lián)動選擇器實現(xiàn)方法

    下面小編就為大家分享一篇vue2.0.js的多級聯(lián)動選擇器實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • 詳解Vue2.0配置mint-ui踩過的那些坑

    詳解Vue2.0配置mint-ui踩過的那些坑

    這篇文章主要介紹了詳解Vue2.0配置mint-ui踩過的那些坑,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • 詳解Vue 事件修飾符capture 的使用

    詳解Vue 事件修飾符capture 的使用

    capture事件修飾符的作用是給元素添加一個監(jiān)聽器,當(dāng)元素發(fā)生冒泡時,先觸發(fā)帶有該修飾符的元素。這篇文章給大家介紹了Vue 事件修飾符capture 的使用,需要的朋友參考下吧
    2017-12-12
  • vue項目多租戶環(huán)境變量的設(shè)置

    vue項目多租戶環(huán)境變量的設(shè)置

    本文主要介紹了vue項目多租戶環(huán)境變量的設(shè)置,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Vue路由router詳解

    Vue路由router詳解

    這篇文章主要介紹了vue router 配置路由的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • vue-drag-resize與輸入框/文本框沖突問題

    vue-drag-resize與輸入框/文本框沖突問題

    這篇文章主要介紹了vue-drag-resize與輸入框/文本框沖突問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue?v-for中key的原理詳析

    vue?v-for中key的原理詳析

    key屬性可以用來提升v-for渲染的效率,vue中使用v-for渲染數(shù)據(jù)的時候,并不會去改變原有的元素和數(shù)據(jù),下面這篇文章主要給大家介紹了關(guān)于vue?v-for中key原理的相關(guān)資料,需要的朋友可以參考下
    2022-04-04
  • Vue使用Proxy代理后仍無法生效的解決

    Vue使用Proxy代理后仍無法生效的解決

    這篇文章主要介紹了Vue使用Proxy代理后仍無法生效的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論