【跨平台app项目源码】【gitlib看源码提交人】【素材解析免费下载源码】iview 源码

时间:2024-12-28 10:14:22 来源:spring事务恢复源码 分类:休闲

1.elementui源码学习之仿写一个el-timeline
2.聊一聊实现Vue路由组件缓存遇到的’坑‘

iview 源码

elementui源码学习之仿写一个el-timeline

       本文记录了仿写el-timeline组件的细节,以深入理解饿了么UI组件的实现机制。本系列文章将持续更新,深入探讨elementui源码的学习与实践。可访问开源仓库,通过npm start运行代码,跨平台app项目源码结合注释辅助理解。

       时间线组件构成包括:时间线小圆点、时间线竖线条、时间戳与具体内容详情四个部分。如图所示。

       时间线组件主要需求包括:按时间线正序或倒序展示、自定义时间线小圆点样式与颜色、使用小图标替代时间线小圆点、控制时间戳与具体内容详情的位置、时间戳的显示与隐藏。

       对官方组件的gitlib看源码提交人见解包括:提供与注入可以简化、时间戳位置优化、简约封装参考其他库组件。Antd与iview的时间线组件参数较为精简。

       回顾知识点:数组方法的使用,如this.$slots.default.reverse();以及`:style`中的四元表达式应用,如`:style="border: ${ elementIcon} ${ borderColor}"`。

       组件代码示例如下:`myTimeline`、`myTimelineItem`。素材解析免费下载源码完整代码在开源仓库,欢迎访问并star。

       若本文对您有所助益,期待您的star,感谢支持!

聊一聊实现Vue路由组件缓存遇到的’坑‘

       项目背景介绍

       在进行公司后台管理系统开发时,遇到了一个在使用keep-alive和vue-router实现的路由组件缓存不生效的问题。该项目基于iview-admin@2.0进行开发,活体检测网络源码全局状态管理采用vuex分module实现,路由配置采用vue-router进行表方式实现。项目属于基于RBAC的后台管理系统,涉及多用户多角色的权限控制和动态系统菜单功能。

       问题解决

       梳理问题并核对官方文档后,发现基本用法和组件缓存原理均无误。但深入检查后发现,问题出现在keep-alive的c#功能源码include参数设置上。iview-admin@2.0中通过路由meata参数——notCache控制组件缓存。官方文档指出,当设为true时,页面在切换标签后不会缓存,但若需要缓存,则无需设置notCache字段,并确保页面组件的name属性与路由配置的name一致。项目中路由配置由后台功能决定,修改无法缓存页面的路由配置的name即可解决。

       研究iview-admin源码

       研究发现,iview-admin中将navTagList、menuList等数据保存在全局vuex的app模块中,navTagList动态更新当前打开的标签页,menuList根据路由记录的meta参数的access字段过滤。cacheList作为getters,计算出需要keep-alive缓存的组件name数组。通过动态修改keep-alive组件的exclude值来更新路由缓存规则。

       iview-admin的局限性

       iview-admin的权限路由控制采用路由meta参数的access数组来标记路由可访问的用户角色,根据路由记录计算用户菜单。这种实现存在不足,需要优化。

       优化方案

       对iview-admin的权限控制和路由配置进行优化,将路由分为基础路由和业务路由。基础路由直接配置到router中,业务路由动态注册。在vuex的user模块中添加获取用户路由配置的action,在用户登录成功后动态注册路由。

       进一步研究

       未来计划深入研究vue-router的view部分源码,理解router-view与keep-alive的关联。后续更新将在此分享。