Vue el-table表头上引入组件不能实时传参解决方法分析
场景还原
产品要求:点击表格的表头,能触发一个下拉的列表,列表能携带表格的筛选条件,获取相应的数据
写了一个demo,来还原一下bug出现的场景:
<div id="demo"> <el-table :data="tableData" style="width: 100%" > <el-table-column prop="date" label="日期" width="180" ></el-table-column> <el-table-column prop="address" label="地址" width="180" > <template slot="header"> <city-component :params="paramsData" ></city-component> </template> </el-table-column> </el-table> </div>
data: { tableData: [], // 表格数据 paramsData: {} // 传递给组件的数据 }, methods: { // 改变paramsData函数 changeParamsDataFn() { this.paramsData = date.now().getTime(); } }
在el-table表格的表头中,引入组件 city-component
,需要将数据paramsData
传递给组件使用。
第一次进入页面时,paramsData
第一次被初始化赋值,DOM渲染el-table完成后,是可以正常使用;但若是需要更改paramsData
的值,并且同步传递给city-component
组件使用时,打印paramsData
的值,是可以看到改值的变化,但是组件却无法接受到变化后的paramsData
的值
解决方法
(1)给el-table加上一个 :key=tableKeyValue
(2)在改变paramsData
后,改变 tableKeyValue
的值
<el-table :key="tableKeyValue" > <!-- 其他跟上面一致 --> </el-table>
methods: { changeParamsDataFn() { this.tableKeyValue = "city" + date.noe(); } }
出现原因
这就得先说说,Vue的渲染机制:虚拟DOM+diff算法
- 根据初始DOM生成旧虚拟DOM;所以使用虚拟DOM的缺点之一便是第一次打开页面,需要更多的时间
- 当有了修改数据的操作时,便会生成新的DOM树
- diff算法就会比较新/旧DOM树,找出变更的DOM
- 将改动的DOM,渲染成真实的DOM;有个优点便是,每次变更DOM,不需要从头到尾查询每一个DOM,只需要找出变更的地方就可
因为表格的DOM没有变化,数据改变后,修改后的DOM与原来的DOM一致,无法重新渲染表格。虽然我们能打印出数据的变化,但是无法将数据传入组件。
加上key值,是为了数据改变的同时,改变table的key值,diff算法就能找出前后表格DOM的不同,就能重新渲染表格,重新把值传入组件
似乎也可以将key值,加在引入组件的单元格上,没有真正写过,下次遇到这类问题可以试试
到此这篇关于Vue el-table表头上引入组件不能实时传参解决方法分析的文章就介绍到这了,更多相关Vue el-table引入组件实时传参内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue 添加和编辑用同一个表单,el-form表单提交后清空表单数据操作
这篇文章主要介绍了vue 添加和编辑用同一个表单,el-form表单提交后清空表单数据操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2020-08-08使用element-ui table expand展开行实现手风琴效果
这篇文章主要介绍了使用element-ui table expand展开行实现手风琴效果,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-03-03axios请求头设置常见Content-Type和对应参数的处理方式
这篇文章主要介绍了axios请求头设置常见Content-Type和对应参数的处理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-03-03
最新评论