继续上一章节进行讲解
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低代码开发平台
请关注我,本星球会持续推出更多的开源项目代码解析,如有更好的意见请留言回复或者私信