Duplicate keys detected: '26'. This may cause an update error

2,469 阅读1分钟

Duplicate keys detected: '26'. This may cause an update error vue警告报错的解决方法

1、检查自己代码循环的数组products是不是有重复使用; 2、如果有重复使用,或者列表返回的id都是相同的,比如报错是26,证明列表id返回的都是26,这时候注意,是循环的**:key="item.product_id"**报的警告;

    <el-table :data="products" border style="width: 100%">
        <el-table-column
                :context="_self"
                inline-template
                label="所属应用">
            <div class="textCen">
                <span v-if="row.app_id=='gift.zhenxin'">臻心礼</span>
                <span v-if="row.app_id=='gift.guafen'">呱分</span>
            </div>
        </el-table-column>
    </el-table>

注意上面一段代码:data="products"是循环的products这个数组

//:key="item.product_id" 这个:key报的警告
    <el-form-item label="选择分类:" :label-width="formLabelWidth" prop="com_name">
        <el-select v-model="formAddCon.product_id" placeholder="请选择商品" @change="changeResourcesValue">
            <el-option
                    v-for="item in products"
                    :label="item.product_name"
                    :key="item.product_id"
                    :value="item.product_id">
            </el-option>
        </el-select>
    </el-form-item>

这上面的代码 v-for="item in products"也是循环的products这个数组

但是呢,这个数组赋值的内容是不相同的,导致循环渲染出来的列表错乱,把对应的数组名字重新定义就解决了。