解决vxe-table的表头动态渲染第一次不显示

1,197 阅读1分钟

问题描述:

        vxe-table表头当使用了(二级/多级表头),设一级表头写死,二级表头动态加载,那么每次赋值二级表头时,值赋上去了,页面不响应,第一次加载不渲染。

\

为什么会这样?

        vxe-table数据响应是根据v-for的key进行检索,如果一级表头key不变,那么就不会重新渲染

\

解决方法:

        给最外层的的for循环的key加随机数,即 :key="index+Math.random()", 每次渲染时,一级表头绑定的key都是不一样,那么就渲染成功啦(Math.round(Math.random() * 1000))一个整数

(给key加了随机数,如果表格是可以有部分是编辑的输入框,可能会出现,输入一次后鼠标会失焦,解决方法:不要直接把随机数加在 :key上,用一个变量从父组件传进来,默认是0,当父组件的动态渲染完成后,执行一次Math.round(Math.random() * 1000) ,理由:(我猜的)当在输入一次的时候,表头是的key会再次随机,那么就是重新渲染,即会造成失焦,可能是直接换了一个dom)

如果觉得进入页面等一点点时间,表头才变,可以给加 :loading="loading" ,即在渲染时,设true,渲染完成后设false