泽兴芝士网

一站式 IT 编程学习资源平台

《若依ruoyi》第十四章:Ruoyi 代码生成(低代码)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低代码开发平台

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

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言