【庖丁解牛】vue-element-admin前端CRUD操作通用框架详解
一、背景
vue-element-admin 框架之所以能够快速定制应用,得益于其通配的CRUD操作,属性配置多样化且个性化,能够满足绝大部分开发需求,也方便了代码生成。
可以深入学习重点源文件是:src/components/Crud/crud.js ,一共863 行代码,以及下图中其它四个vue组件,形成了对通用CRUD操作的高级封装。
来一段该文件的历史:
在该文件之前有一个老版本的文件,在src/mixins 文件夹下。有4处使用的地方, 在源码版本记录中观察到:
- 在2019年12月9日老版本的文件停止更新了,重新添加了
src/components/crud/crud.js 以及其它组件,包括表单、分页、搜索框、表格; - 在2019年12月12日更改了现在的名字,并以此为基础进行迭代。
二、文件一览
共计9个函数,最重要的就是CRUD(options) 函数,封装了配置项、方法、钩子函数。
- CRUD(options)
- callVmHook(crud, hook)
调用钩子函数 - mergeOptions(src, opts)
合并配置项,将传入的参数合并到当前实例中 - presenter(crud)
生成crud - header()
头部 - pagination()
分页 - form(defaultForm)
表单 - crud(options = {})
三、配置项
默认配置项有:
四、方法
4.1 普通方法
4.2 钩子函数
钩子函数应该说是做的很精细,包含各个用户操作的事件。
钩子函数与vue生命周期的执行顺序应该是我们最关注的,因为事件的起始影响着编程的思路。
五、小试牛刀
- 编写后台接口
- 引入各个组件和数据API接口函数
- 声明默认表格对象
defaultForm 该对象对应着表格要显示的数据列 - 定义函数
cruds() 该函数返回第二节中的CRUD(options) 实例,参数options是一个可配置对象,根据需求更改配置元素的值。 - 混入对象
通过vue混入属性,将通用CRUD暴露的组件函数拿过来mixins: [presenter(), header(), form(defaultForm), crud()]
- 请求后台数据
通过钩子函数CRUD.HOOK.beforeRefresh
六、拨云见雾
通用组件怎么运行起来的?
离不开assign,vm.$option,callVm
|