vue table 组件求教

2023-12-12 13:32:51 +08:00
 qingshui33

现在想要在 vue 项目中编写一个类似于 element-plus 中 el-table 的组件,使用方法和 element 中类似,如下

<el-table :data="tableData" style="width: 100%">
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
    <el-table-column prop="address" label="Address" />
</el-table>

但是遇到了个问题,就是该如何在 el-table 组件中获取 el-table-column 中传递过来的属性呢

1609 次点击
所在节点    Vue.js
18 条回复
sanmaozhao
2023-12-12 13:38:48 +08:00
既然都有参考的目标了,那就去看 element-plus 中 el-table 的组件 的源码啊
bojackhorseman
2023-12-12 13:48:06 +08:00
通过 refs 吧
qingshui33
2023-12-12 14:05:18 +08:00
@sanmaozhao 上午看过来着,但是当时没太看懂,等下我再去看看
qingshui33
2023-12-12 14:05:45 +08:00
@bojackhorseman 是在插槽上使用吗
liuhuihao
2023-12-12 14:30:29 +08:00
@qingshui33 #3 看下 element 的源码吧,element 是在 table 层建了一个 store ,然后 el-table-column mounted 的时候 调用了 store 的 insertColumn 保存起来。其实就相当于一个 局部的 store 大家都共享里面的值。

element-plus/packages/components/table/src/store/index.ts #73
element-plus/packages/components/table/src/table-column/index.ts #145
kylebing
2023-12-12 14:35:15 +08:00
siguapajamas
2023-12-12 15:00:25 +08:00
@liuhuihao 哥,想请教一下您,我当初在研究从零搭建 ele table 的时候也看到这个地方,搭建了小型的 store ,但是 B 站教程零零碎碎看不全,请问除了看源码你知道哪里有公开的教程嘛?
sjhhjx0122
2023-12-12 15:07:18 +08:00
从 el-table 上依赖注入,el-table-column 传回去
qingshui33
2023-12-12 15:08:50 +08:00
@liuhuihao 好的,感谢感谢,我去研究研究
qingshui33
2023-12-12 15:09:20 +08:00
@kylebing 好的👌
qingshui33
2023-12-12 15:10:15 +08:00
@sjhhjx0122 可以的,我研究研究哈
liuhuihao
2023-12-12 15:14:23 +08:00
@siguapajamas 这个我也不太清楚有没有哈,我也是临时看的源码
zcf0508
2023-12-12 15:17:18 +08:00
siguapajamas
2023-12-12 15:17:45 +08:00
@liuhuihao 好 谢谢你的回复
qingshui33
2023-12-12 15:31:37 +08:00
@zcf0508 这个可以的,收藏了,我试试去
sjhhjx0122
2023-12-12 16:50:20 +08:00
@qingshui33 最后的那个链接就是我说的那个方法
chenjiangui998
2023-12-12 20:57:07 +08:00
table provide 一个 register 的方法
qingshui33
2023-12-12 22:00:42 +08:00
@sjhhjx0122 我看了那个文章,后来感觉他那个不太适合我的场景,找了下,掘金的这篇文章比较适合我现在遇到的问题 https://juejin.cn/post/6900046013726195720
@chenjiangui998 嗯嗯,好的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/999671

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX