《若依ruoyi》第十四章:Ruoyi 代码生成(低代码)vue逻辑详解三(若依vue教程)

继续上一章节进行讲解

1、vue table的分页模式

分页界面实现效果图如下

《若依ruoyi》第十四章:Ruoyi 代码生成(低代码)vue逻辑详解三(若依vue教程)

对应代码片段并针对代码进行说明

<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,实现的功能是可以进行生成代码结果进行预览

《若依ruoyi》第十四章:Ruoyi 代码生成(低代码)vue逻辑详解三(若依vue教程)

代码实现如下

<!-- 预览界面 --><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低代码开发平台

请关注我,本星球会持续推出更多的开源项目代码解析,如有更好的意见请留言回复或者私信

相关新闻

联系我们
联系我们
公众号
公众号
在线咨询
分享本页
返回顶部