Vue dynamically adds and removes subcomponents. The parent component does not correspond to the child component data?

function:
1. Click "add button" in the parent component, add a new child component
2, click "delete button" in the child component, and delete the corresponding child component

.

problem encountered:
when the child component deletes content, the child component is not deleted.
as shown in figure

Source Code:
parent component Parent.vue Source Code
< template >

<div>
    <button @click="add"></button>
    <children 
        v-for="(item,index) in arr" 
        :key="index"
        :index="index"
        @remove="remove">
    </children>
</div>

< / template >

< script >
import Children from"@ / components/Children"

export default {

data() {
    return {
        t:0,
        arr:[]
    };
},
components: {
    Children
},
methods: {
    // 
    add(){
        this.arr.push({})
    },

    //
    remove(n){
        this.arr.splice(n,1); 
    }
}

};
< / script >

subcomponent Children.vue source code
< template >

<div>
    <div class="box">
        <input type="text" placeholder="" />
        <button @click="del(index)"></button>
    </div>
</div>

< / template >
< script >
export default {

data() {
    return {

    };
},
props: ["index"],
methods: {
    del(n){
        this.$emit("remove",n);
    }
}

};
< / script >

< style scoped >

span{
    margin-right: 10px
}

.box{
    display: flex;
    margin: 10px 0;
}

< / style >

Oct.19,2021

reason: incorrect subscript

< button @ click= "del (index)" > Delete < / button >

get the index here? No,

del () {

   // this.index
    this.$emit('remove', this.index);
}

I think your answer is here: https://codeshelper.com/q/10.


data maintains a source array of data for circular rendering. However, when the key is bound to the index in the list, there may be problems with component destruction when deleted. This is due to the component destruction mechanism within Vue, so key is bound as a uniqueId as much as possible.

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-1b3b589-2b7d2.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-1b3b589-2b7d2.MAI); waiting for someone to free some space... (errno: 28 "No space left on device")
Need Help?