《若依ruoyi》第十四章:Ruoyi 代码生成(低代码)vue逻辑详解三(若依vue教程)
继续上一章节进行讲解
1、vue table的分页模式
分页界面实现效果图如下
对应代码片段并针对代码进行说明
<Pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList"/>
v-show="total>0" //当total大于0,组件才显示
:total="total" //绑定变量,总记录数
:page.sync="queryParams.pageNum" //显示的第几页
:limit.sync="queryParams.pageSize" //每页显示的数量
@pagination="getList" //绑定的函数,点击分页后触发的函数
2、若依分页组件封装
若依对分页做成一个封装组件,所以页面直接引入就可以。在我们研读代码中,并没有直接 import分页组件的代码,下面是原因。
作者在mian.js 通过下面两行代码直接引入作为全局组件,所以在局部的也没就不需要重复
import
// 分页组件import Pagination from "@/components/Pagination";Vue.component('Pagination', Pagination)
分页组件代码路径/src/components/Pagination
props: { total: { required: true, type: Number }, page: { type: Number, default: 1 }, limit: { type: Number, default: 20 }, pageSizes: { type: Array, default() { return [10, 20, 30, 50] } }, // 移动端页码按钮的数量端默认值5 pagerCount: { type: Number, default: document.body.clientWidth < 992 ? 5 : 7 }, layout: { type: String, default: 'total, sizes, prev, pager, next, jumper' }, background: { type: Boolean, default: true }, autoScroll: { type: Boolean, default: true }, hidden: { type: Boolean, default: false }},
分页作为组件,需要外部传入参数,其中组件里面props就是定义外部入参,例如 total参数中的required是true,表示total是必传,type是Number,表示total的数据类型是数字,如果传入中文等会出现异常
封装的分页组件最终使用element ui 的分页组件,具体组件连接参考https://element.eleme.cn/#/zh-CN/component/pagination#dai-you-bei-jing-se-de-fen-ye
<el-pagination :background="background" :current-page.sync="currentPage" :page-size.sync="pageSize" :layout="layout" :page-sizes="pageSizes" :pager-count="pagerCount" :total="total" v-bind="$attrs" @size-change="handleSizeChange" @current-change="handleCurrentChange"/>
@size-change="handleSizeChange" 当选择的页数改变,分页组件会调用handleSizeChange函数,handleSizeChange函数具体实现如下
handleSizeChange(val) { if (this.currentPage * val > this.total) { this.currentPage = 1 } this.$emit('pagination', { page: this.currentPage, limit: val }) if (this.autoScroll) { scrollTo(0, 800) }},
其中this.$emit('pagination', { page: this.currentPage, limit: val })是回调父组件的pagination函数
<pagination v-show="total>0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" @pagination="getList"/>
从index的分页代码可以看出分页组件handleSizeChange会调用@pagination函数,index的pagination函数赋值是getList函数,所以最终执行函数是getList
3、预览界面
界面效果图如下,弹出窗口,窗口包含几个tab,实现的功能是可以进行生成代码结果进行预览
代码实现如下
<!-- 预览界面 --><el-dialog :title="preview.title" :visible.sync="preview.open" width="80%" top="5vh" append-to-body class="scrollbar"> <el-tabs v-model="preview.activeName"> <el-tab-pane v-for="(value, key) in preview.data" :label="key.substring(key.lastIndexOf('/') 1,key.indexOf('.vm'))" :name="key.substring(key.lastIndexOf('/') 1,key.indexOf('.vm'))" :key="key" > <el-link :underline="false" icon="el-icon-document-copy" v-clipboard:copy="value" v-clipboard:success="clipboardSuccess" style="float:right">复制</el-link> <pre><code class="hljs" v-html="highlightedCode(value, key)"></code></pre> </el-tab-pane> </el-tabs></el-dialog>
下面对el-dialog和el-tabs标签进行解说
适用场景
新增和编辑操作想要以弹框的方式显示,使用到el-dialog
知识点
el-dialog的title属性设置标题
el-dialog的visible.sync属性控制弹框的显示
el-dialog的append-to-body属性支持弹框中继续打开弹框
el-dialog的before-close属性关闭按钮的钩子
span的slot='footer'属性弹框底部设置
el-dialog的center属性标题和底部居中显示
官网地址:https://element.eleme.cn/#/zh-CN/component/dialog
适用场景
与导航栏相似,项目中常见的是点击某个导航栏,主页面(el-main)模块的最上方会显示我们的标签栏集合,点击不同的导航栏,标签栏会在不断追加,若点击到标签集合中已存在,就进入选中指定的标签栏,显示页面
知识点
el-tabs嵌套el-tab-pane使用
el-tabs的v-model对应el-tab-pane的name
el-tabs的type可以指定为card,border-card
el-tab-pane的label为显示的标签内容,标签的内容在首尾标签内部
el-tabs可以设置closable,editable,addable,分别设置tab-remove,edit,tab-add动态修改标签集合
还有tab-click钩子
el-tabs中设置tab-position,修改标签位置,可以为top,bottom,left,right
官网地址:https://element.eleme.cn/#/zh-CN/component/tabs
4、未来计划
1、ruoyi非分离版本拆解
2、ruoyi-vue-pro:讲解工作流
3、ruoyi-vue-pro:支付模块,电商模块
4、基于ruoyi-vue-pro项目开发
5、JEECG低代码开发平台
请关注我,本星球会持续推出更多的开源项目代码解析,如有更好的意见请留言回复或者私信