Vue 中el-table-column 进行循环,页面没渲染成功

文章目录


前言

实现效果:el-table-column 进行循环,使之代码简化

遇到的问题: data进行默认赋值,操作列的删除都可以出来,其他表格里面的数据没出来


效果图

示例:

代码示例

cpp 复制代码
<template>
    <div class="app-container">
        <el-row :gutter="20">
            <el-col>
                <div>数据条数: {{ recycleBinList.length }}</div>
                <el-table v-loading="loading" :data="recycleBinList" border style="width: 100%">
                    <el-table-column v-for="(column, index) in columns" :key="index" :prop="column.prop"
                        :label="column.label" align="center" :show-overflow-tooltip="true">
                        <template v-if="column.prop === 'caozuo'" slot-scope="scope">
                            <el-button size="small" type="danger" @click="handleDelete(scope.row)">
                                删除
                            </el-button>
                        </template>
                        <template v-else slot-scope="scope">
                            {{ scope.row[column.prop] }} <!-- 显示其他列的数据 -->
                        </template>
                    </el-table-column>
                </el-table>
            </el-col>
        </el-row>
    </div>
</template>

<script>
export default {
    name: "configAll",
    data() {
        return {
            columns: [
                { width: '200px', label: '编号', prop: 'numberID' },
                { width: 'auto', label: '唯一ID', prop: 'id' },
                { width: '150px', label: '操作', prop: 'caozuo' },
            ],
            loading: false,
            recycleBinList: [
                {
                    numberID: 1, id: 1, fileName: '111'
                }
            ],
        };
    },
    created() {
        console.log('组件 created 钩子执行',this.recycleBinList);
    },
    mounted() {
        console.log('组件 mounted 钩子执行',this.recycleBinList);
    },
};
</script>

看这个这个代码分析了半天才发现

可能出现的问题及原因

作用域理解混淆:

slot-scope用于在插槽中获取父组件传递过来的数据,它创建了一个特定的作用域,而v-if是基于 Vue 的响应式数据进行条件判断来决定元素是否渲染。当同时使用时,如果对它们各自的作用域以及数据的响应式变化机制理解不清楚,就容易出现渲染不符合预期的情况。

例如,在v-if判断中使用的变量,可能在slot-scope的作用域内不存在或者其值的变化没有被正确地监测到,导致元素渲染或隐藏的逻辑出现错误。
渲染顺序问题:

Vue 在解析模板时,对于v-if和插槽(包含slot-scope)的处理顺序可能会影响最终的渲染结果。如果v-if的条件判断依赖于插槽内传递的数据,而插槽数据的传递和解析顺序出现问题,就可能导致v-if的判断不准确,进而影响数据的正确渲染。

解决思路

明确作用域和数据来源:

仔细梳理slot-scope中接收到的数据结构以及在v-if判断中使用的变量来源。确保v-if中使用的变量是在slot-scope作用域内能够正确获取到的,并且是响应式的数据(如果需要响应式变化的话)。

cpp 复制代码
 <template slot-scope="scope">
    <div v-if="isCaozuoColumn(column.prop)">
       <el-button size="small" type="danger" @click="handleDelete(scope.row)">
              删除
                </el-button>
       </div>
    <div v-else>
   {{ scope.row[column.prop] }}
       </div>
     </template>```

总而言之:就是  ** slot-scope和v-if同时使用** 导致的数据渲染问题

**Ending...**
相关推荐
无巧不成书02181 小时前
Windows PowerShell执行策略详解:从npm报错到完美解决
前端·windows·npm·powershell执行策略·执行策略·npm.ps1·脚本报错
Z兽兽8 小时前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang8 小时前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda8 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06269 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~9 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle9 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界10 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser10 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码203511 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos