vue+element分页器组件封装

本文介绍了一个基于Vue和Element UI封装的分页组件实例。该组件提供了灵活配置的分页功能,包括调整每页显示的数据数量、当前页码及总记录数等,并通过事件传递与父组件交互实现数据加载。文章详细展示了组件代码结构和页面应用示例。

vue+element分页器组件封装

分页组件

<template>
  <!-- 分页组件的封装 -->
  <div class="pagination">
    <el-pagination
      @size-change="sizeChange"
      @current-change="currentChange"
      :page-sizes="[1, 5, 10]"
      layout="total, sizes, prev, pager, next, jumper"
      :current-page.sync="pageNum"
      :page-size="pageSize"
      :total="total"
      :small="small"
    >
    </el-pagination>
    <!-- layout="total, sizes, prev, pager, next, jumper" -->
  </div>
</template>

<script>
export default {
  name: "Paging",
  data() {
    return {
      pageNum: 1, //当前页数
    };
  },
  //子组件接收父组件的值
  props: {
    total: {
      //总条目数
      required: false, //是否必须
      default: 0, //默认值
    },
    pageSize: {
      required: false, //是否必须
      default: 10, //默认值(默认显示10条)
    },
    small: {
      //是否使用小型分页样式
      required: false, //是否必须
      type: Boolean, //类型
      default: false, //默认值
    },
  },
  //计算属性  计算属性是基于他们的依赖做缓存
  // (如果计算的逻辑大的话,可以用这个,比方说你先循环100次,再循环1000次,他会把上一次的循环也加上去,也就是缓存)
  computed: {},
  //侦听器 响应数据的变化
  watch: {
    //监听页数变化
    pageNum(val, index) {
      console.log(val); //值
      console.log(index); //下标
      // 改变这个值并不会触发 handleCurrentChange
      if (typeof val === "number") {
        this.pageNum = val;
      }
    },
  },
  methods: {
    // 当前页变化
    sizeChange(val) {
      // console.log(val);
      //子组件向父组件传值
      this.$emit("sizeChange", val);
    },
    // size变化
    currentChange(val) {
      // console.log(val);
      //子组件向父组件传值
      this.$emit("currentChange", val);
    },
  },
};
</script>

<style lang="scss" scoped>
.pagination {
  margin: 20px 0;
  text-align: right;
}

</style>

在页面中使用分页组件

  <div v-if="this.total" class="totalclass">
      <Paging
        :pageNum="this.form.page"
        :total="this.total"
        :pageSize="this.form.size"
        :small="true"
        @sizeChange="sizeChange"
        @currentChange="currentChange"
      ></Paging>
    </div>

引入组件

import Paging from "@/components/public/paging.vue";
data() {
    return {
      total: 0,
      form: {
        page: 1,
        size: 10,
      },
  }
}

事件

//上一页下一页按钮
    currentChange(val) {
      this.form.page = val;
      this.getTable();
    },
    //每页显示几条数据按钮
    sizeChange(val) {
      this.form.size = val;
      this.getTable();
    },
    //调取接口
    getTable() {
      getdatas({//这里是封装的接口
        curPage: this.form.page,
        pageSize: this.form.size,
      }).then((res) => {
        if (res.state) {
          this.total = res.data.total;
        }
      });
    },
### 创建基于 Vue 3 和 Element Plus 的 CRUD 组件 创建一个功能齐全的 CRUD (Create, Read, Update, Delete) 组件涉及多个方面,包括数据获取、表单处理以及状态管理。下面是一个详细的指南来构建这样的组件。 #### 使用组合 API 构建响应式逻辑 Vue 3 推出了 Composition API 来替代 Options API,在编写复杂业务逻辑时提供了更好的灵活性和可读性[^1]: ```javascript import { ref } from 'vue' // 定义初始数据结构 const items = ref([]) async function fetchItems() { const response = await fetch('/api/items') items.value = await response.json() } fetchItems() function addItem(item) { // 假设有一个 POST 请求用于新增项目 } function updateItem(id, updates) { // 更新特定 ID 对应的数据项 } function deleteItem(id) { // 删除指定 ID 的记录 } ``` #### 表格展示与分页支持 Element Plus 提供了丰富的 UI 组件库,其中 `el-table` 是用来显示表格化数据的理想选择。为了实现高效的页面加载体验,通常还需要加入分页控件: ```html <template> <div class="crud-container"> <!-- 数据列表 --> <el-table :data="items" style="width: 100%"> <el-table-column prop="name" label="Name"></el-table-column> <el-table-column fixed="right" width="200px"> <template slot-scope="scope"> <el-button @click="editRow(scope.row)">Edit</el-button> <el-popconfirm title="Are you sure?" @onConfirm="deleteRow(scope.$index)"> <el-button type="danger">Delete</el-button> </el-popconfirm> </template> </el-table-column> </el-table> <!-- 分页器 --> <el-pagination layout="prev, pager, next" :total="totalCount"></el-pagination> <!-- 新增/编辑对话框 --> <el-dialog v-model="dialogVisible" title="Form Title"> <el-form :model="formModel"> <el-form-item label="Name"> <el-input v-model="formModel.name"></el-input> </el-form-item> </el-form> <span slot="footer" class="dialog-footer"> <el-button @click="closeDialog()">Cancel</el-button> <el-button type="primary" @click="submitForm()">Submit</el-button> </span> </el-dialog> </div> </template> ``` #### 将操作封装成独立函数并优化用户体验 对于每一个基本的操作(增加、修改、删除),都应该定义相应的事件处理器,并考虑如何提升用户的交互感受。比如当执行成功后给出提示信息;失败情况下则捕获错误并向用户反馈具体原因。 通过上述方法可以有效地利用 Vue 3 及其生态系统中的工具和技术来开发高质量且易于维护的应用程序界面。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值