The vue custom component is called multiple times by the same page, and the data is overwritten.

I wrote a component myself. The bar chart, data and chart names in echarts are dynamic.
wrote

in column.vue.
props:{
    column:{
        text:{
            type:String,
            default:""
        },
        series: [Object],
    },
},
mounted(){
    //
    this.myChart.setOption({
        series:this.column.series
    }
}

then call

in charts.vue
<template>
    <div>
        <v-column :column="column"></v-column>
        <v-column :column="column2"></v-column>
    </div>
</template>

<script>
    import vColumn from "../common/Column.vue";
    export default {
        data() {
            return {
                column:{
                    text:"",
                    series: [
                        {
                            name: "1",
                            type: "bar",
                            barWidth: "60%",
                            data: [10, 52, 200, 334, 390, 330, 220]
                        }
                    ],
                },
                column2:{
                    text:"2",
                    series: [
                        {
                            name: "2",
                            type: "bar",
                            barWidth: "60%",
                            data: [10, 100,20,40,50,120]
                        }
                    ],
                }
            }
        },
        mounted() {},
        methods: {},
        components: {
            vColumn
        }
    }
</script>

but only the first chart shown has data, and the data is colum2. If the same page calls the same component many times, but the data is different, what should be done, or how to call locally, to avoid data contamination in the same page
this is the first v-column

clipboard.png
v-column

clipboard.png

Mar.23,2021

there is a good chance that there is something wrong with echarts init. Did you use class or id selector to select elements to init
wrong version

<template>
    <div id="chart"></div>
</template>
<script>
import * as echarts from 'echarts';
export default{
    mounted(){
        this.myChart=echarts.init(document.getElementById('chart'));
        ...
    }
}
<script>

correct version

<template>
    <div ref="chart"></div>
</template>
<script>
import * as echarts from 'echarts';
export default{
    mounted(){
        this.myChart=echarts.init(this.$el);//this.$ref.chart
        ...
    }
}
<script>

to ensure that the data is rendered after the data is requested, it is best to use v-if to control

MySQL Query : SELECT * FROM `codeshelper`.`v9_news` WHERE status=99 AND catid='6' ORDER BY rand() LIMIT 5
MySQL Error : Disk full (/tmp/#sql-temptable-64f5-1e69ae9-45d5c.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
MySQL Errno : 1021
Message : Disk full (/tmp/#sql-temptable-64f5-1e69ae9-45d5c.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?