使用Element UI实现前端分页,及el-table表格跨页选择数据,切换分页保留分页数据,限制多选数量

文章目录

      • 一、前端分页
        • 1、模板部分 (\<template>)
        • 2、数据部分 (data)
        • 3、计算属性 (computed)
        • 4、方法 (methods)
      • 二、跨页选择
        • 1、模板部分 (\<template>)
        • 2、数据部分 (data)
        • 3、方法 (methods)
      • 三、限制数量
        • 1、模板部分 (\<template>)
        • 2、数据部分 (data)
        • 3、方法 (methods)
      • 四、效果展示

一、前端分页

在现代Web应用中,数据量庞大,一次性加载所有数据,不仅会增加页面加载时间,还会消耗过多的网络资源和客户端内存。因此,分页技术成为了优化用户体验和提高性能的关键手段之一。

而作为一名前端开发,分页功能我们经常会用到,而且有时候,后端会把数据一次性给我们,需要我们自己处理数据,做前端分页。使用Element UI实现前端分页是一项常见的需求。Element UI提供了一个方便的 Pagination 组件,可以用来实现分页功能。以下是一个简单的示例,展示了如何实现前端分页。

1、模板部分 (<template>)
  • 使用el-table展示当前页的数据。
  • 使用el-pagination组件实现分页控件,绑定相关属性和事件。
<el-table :data="currentPageData" style="width: 100%">
      <el-table-column prop="id" label="id" width="180"></el-table-column>
      <el-table-column prop="name" label="Name" width="180"></el-table-column>
      <el-table-column prop="value" label="value"></el-table-column>
</el-table>

<el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage" :page-sizes="[10, 20, 30, 40, 50]"
      :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="tableData.length"
      style="text-align: right; margin-top: 20px;">
</el-pagination>
2、数据部分 (data)
  • tableData:包含所有数据的数组。
  • currentPage:当前页码。
  • pageSize:每页显示的数据条数。
data() {
    return {
      tableData: [{ "id": 1, "name": "名字1", "value": 1 }, { "id": 2, "name": "名字2", "value": 2 }, { "id": 3, "name": "名字3", "value": 3 }, { "id": 4, "name": "名字4", "value": 4 }, { "id": 5, "name": "名字5", "value": 5 }, { "id": 6, "name": "名字6", "value": 6 }, { "id": 7, "name": "名字7", "value": 7 }, { "id": 8, "name": "名字8", "value": 8 }, { "id": 9, "name": "名字9", "value": 9 }, { "id": 10, "name": "名字10", "value": 10 }, { "id": 11, "name": "名字11", "value": 11 }, { "id": 12, "name": "名字12", "value": 12 }, { "id": 13, "name": "名字13", "value": 13 }, { "id": 14, "name": "名字14", "value": 14 }, { "id": 15, "name": "名字15", "value": 15 }, { "id": 16, "name": "名字16", "value": 16 }, { "id": 17, "name": "名字17", "value": 17 }, { "id": 18, "name": "名字18", "value": 18 }, { "id": 19, "name": "名字19", "value": 19 }, { "id": 20, "name": "名字20", "value": 20 }, { "id": 21, "name": "名字21", "value": 21 }, { "id": 22, "name": "名字22", "value": 22 }, { "id": 23, "name": "名字23", "value": 23 }, { "id": 24, "name": "名字24", "value": 24 }, { "id": 25, "name": "名字25", "value": 25 }, { "id": 26, "name": "名字26", "value": 26 }, { "id": 27, "name": "名字27", "value": 27 }, { "id": 28, "name": "名字28", "value": 28 }, { "id": 29, "name": "名字29", "value": 29 }, { "id": 30, "name": "名字30", "value": 30 }, { "id": 31, "name": "名字31", "value": 31 }, { "id": 32, "name": "名字32", "value": 32 }, { "id": 33, "name": "名字33", "value": 33 }, { "id": 34, "name": "名字34", "value": 34 }, { "id": 35, "name": "名字35", "value": 35 }, { "id": 36, "name": "名字36", "value": 36 }, { "id": 37, "name": "名字37", "value": 37 }, { "id": 38, "name": "名字38", "value": 38 }, { "id": 39, "name": "名字39", "value": 39 }, { "id": 40, "name": "名字40", "value": 40 }, { "id": 41, "name": "名字41", "value": 41 }, { "id": 42, "name": "名字42", "value": 42 }, { "id": 43, "name": "名字43", "value": 43 }, { "id": 44, "name": "名字44", "value": 44 }, { "id": 45, "name": "名字45", "value": 45 }, { "id": 46, "name": "名字46", "value": 46 }, { "id": 47, "name": "名字47", "value": 47 }, { "id": 48, "name": "名字48", "value": 48 }, { "id": 49, "name": "名字49", "value": 49 }, { "id": 50, "name": "名字50", "value": 50 }, { "id": 51, "name": "名字51", "value": 51 }, { "id": 52, "name": "名字52", "value": 52 }, { "id": 53, "name": "名字53", "value": 53 }, { "id": 54, "name": "名字54", "value": 54 }, { "id": 55, "name": "名字55", "value": 55 }, { "id": 56, "name": "名字56", "value": 56 }, { "id": 57, "name": "名字57", "value": 57 }, { "id": 58, "name": "名字58", "value": 58 }, { "id": 59, "name": "名字59", "value": 59 }, { "id": 60, "name": "名字60", "value": 60 }, { "id": 61, "name": "名字61", "value": 61 }, { "id": 62, "name": "名字62", "value": 62 }, { "id": 63, "name": "名字63", "value": 63 }, { "id": 64, "name": "名字64", "value": 64 }, { "id": 65, "name": "名字65", "value": 65 }, { "id": 66, "name": "名字66", "value": 66 }, { "id": 67, "name": "名字67", "value": 67 }, { "id": 68, "name": "名字68", "value": 68 }, { "id": 69, "name": "名字69", "value": 69 }, { "id": 70, "name": "名字70", "value": 70 }, { "id": 71, "name": "名字71", "value": 71 }, { "id": 72, "name": "名字72", "value": 72 }, { "id": 73, "name": "名字73", "value": 73 }, { "id": 74, "name": "名字74", "value": 74 }, { "id": 75, "name": "名字75", "value": 75 }, { "id": 76, "name": "名字76", "value": 76 }, { "id": 77, "name": "名字77", "value": 77 }, { "id": 78, "name": "名字78", "value": 78 }, { "id": 79, "name": "名字79", "value": 79 }, { "id": 80, "name": "名字80", "value": 80 }, { "id": 81, "name": "名字81", "value": 81 }, { "id": 82, "name": "名字82", "value": 82 }, { "id": 83, "name": "名字83", "value": 83 }, { "id": 84, "name": "名字84", "value": 84 }, { "id": 85, "name": "名字85", "value": 85 }, { "id": 86, "name": "名字86", "value": 86 }, { "id": 87, "name": "名字87", "value": 87 }, { "id": 88, "name": "名字88", "value": 88 }, { "id": 89, "name": "名字89", "value": 89 }, { "id": 90, "name": "名字90", "value": 90 }, { "id": 91, "name": "名字91", "value": 91 }, { "id": 92, "name": "名字92", "value": 92 }, { "id": 93, "name": "名字93", "value": 93 }, { "id": 94, "name": "名字94", "value": 94 }, { "id": 95, "name": "名字95", "value": 95 }, { "id": 96, "name": "名字96", "value": 96 }, { "id": 97, "name": "名字97", "value": 97 }, { "id": 98, "name": "名字98", "value": 98 }, { "id": 99, "name": "名字99", "value": 99 }, { "id": 100, "name": "名字100", "value": 100 }, { "id": 101, "name": "名字101", "value": 101 }, { "id": 102, "name": "名字102", "value": 102 }, { "id": 103, "name": "名字103", "value": 103 }, { "id": 104, "name": "名字104", "value": 104 }, { "id": 105, "name": "名字105", "value": 105 }, { "id": 106, "name": "名字106", "value": 106 }, { "id": 107, "name": "名字107", "value": 107 }, { "id": 108, "name": "名字108", "value": 108 }, { "id": 109, "name": "名字109", "value": 109 }, { "id": 110, "name": "名字110", "value": 110 }, { "id": 111, "name": "名字111", "value": 111 }, { "id": 112, "name": "名字112", "value": 112 }, { "id": 113, "name": "名字113", "value": 113 }, { "id": 114, "name": "名字114", "value": 114 }, { "id": 115, "name": "名字115", "value": 115 }, { "id": 116, "name": "名字116", "value": 116 }, { "id": 117, "name": "名字117", "value": 117 }, { "id": 118, "name": "名字118", "value": 118 }, { "id": 119, "name": "名字119", "value": 119 }, { "id": 120, "name": "名字120", "value": 120 }, { "id": 121, "name": "名字121", "value": 121 }, { "id": 122, "name": "名字122", "value": 122 }, { "id": 123, "name": "名字123", "value": 123 }, { "id": 124, "name": "名字124", "value": 124 }, { "id": 125, "name": "名字125", "value": 125 }, { "id": 126, "name": "名字126", "value": 126 }, { "id": 127, "name": "名字127", "value": 127 }, { "id": 128, "name": "名字128", "value": 128 }, { "id": 129, "name": "名字129", "value": 129 }, { "id": 130, "name": "名字130", "value": 130 }, { "id": 131, "name": "名字131", "value": 131 }, { "id": 132, "name": "名字132", "value": 132 }, { "id": 133, "name": "名字133", "value": 133 }, { "id": 134, "name": "名字134", "value": 134 }, { "id": 135, "name": "名字135", "value": 135 }, { "id": 136, "name": "名字136", "value": 136 }, { "id": 137, "name": "名字137", "value": 137 }, { "id": 138, "name": "名字138", "value": 138 }, { "id": 139, "name": "名字139", "value": 139 }, { "id": 140, "name": "名字140", "value": 140 }, { "id": 141, "name": "名字141", "value": 141 }, { "id": 142, "name": "名字142", "value": 142 }, { "id": 143, "name": "名字143", "value": 143 }, { "id": 144, "name": "名字144", "value": 144 }, { "id": 145, "name": "名字145", "value": 145 }, { "id": 146, "name": "名字146", "value": 146 }, { "id": 147, "name": "名字147", "value": 147 }, { "id": 148, "name": "名字148", "value": 148 }, { "id": 149, "name": "名字149", "value": 149 }, { "id": 150, "name": "名字150", "value": 150 }, { "id": 151, "name": "名字151", "value": 151 }, { "id": 152, "name": "名字152", "value": 152 }, { "id": 153, "name": "名字153", "value": 153 }, { "id": 154, "name": "名字154", "value": 154 }, { "id": 155, "name": "名字155", "value": 155 }, { "id": 156, "name": "名字156", "value": 156 }, { "id": 157, "name": "名字157", "value": 157 }, { "id": 158, "name": "名字158", "value": 158 }, { "id": 159, "name": "名字159", "value": 159 }, { "id": 160, "name": "名字160", "value": 160 }, { "id": 161, "name": "名字161", "value": 161 }, { "id": 162, "name": "名字162", "value": 162 }, { "id": 163, "name": "名字163", "value": 163 }, { "id": 164, "name": "名字164", "value": 164 }, { "id": 165, "name": "名字165", "value": 165 }, { "id": 166, "name": "名字166", "value": 166 }, { "id": 167, "name": "名字167", "value": 167 }, { "id": 168, "name": "名字168", "value": 168 }, { "id": 169, "name": "名字169", "value": 169 }, { "id": 170, "name": "名字170", "value": 170 }, { "id": 171, "name": "名字171", "value": 171 }, { "id": 172, "name": "名字172", "value": 172 }, { "id": 173, "name": "名字173", "value": 173 }, { "id": 174, "name": "名字174", "value": 174 }, { "id": 175, "name": "名字175", "value": 175 }, { "id": 176, "name": "名字176", "value": 176 }, { "id": 177, "name": "名字177", "value": 177 }, { "id": 178, "name": "名字178", "value": 178 }, { "id": 179, "name": "名字179", "value": 179 }, { "id": 180, "name": "名字180", "value": 180 }, { "id": 181, "name": "名字181", "value": 181 }, { "id": 182, "name": "名字182", "value": 182 }, { "id": 183, "name": "名字183", "value": 183 }, { "id": 184, "name": "名字184", "value": 184 }, { "id": 185, "name": "名字185", "value": 185 }, { "id": 186, "name": "名字186", "value": 186 }, { "id": 187, "name": "名字187", "value": 187 }, { "id": 188, "name": "名字188", "value": 188 }, { "id": 189, "name": "名字189", "value": 189 }, { "id": 190, "name": "名字190", "value": 190 }, { "id": 191, "name": "名字191", "value": 191 }, { "id": 192, "name": "名字192", "value": 192 }, { "id": 193, "name": "名字193", "value": 193 }, { "id": 194, "name": "名字194", "value": 194 }, { "id": 195, "name": "名字195", "value": 195 }, { "id": 196, "name": "名字196", "value": 196 }, { "id": 197, "name": "名字197", "value": 197 }, { "id": 198, "name": "名字198", "value": 198 }, { "id": 199, "name": "名字199", "value": 199 }, { "id": 200, "name": "名字200", "value": 200 }],
      currentPage: 1,// 当前页
      pageSize: 10, // 每页多少条数据
    };
  },
3、计算属性 (computed)
  • currentPageData:根据当前页码和每页条数计算当前页应该显示的数据。
computed: {
    //当前页数据
    currentPageData() {
      const start = (this.currentPage - 1) * this.pageSize;
      const end = this.currentPage * this.pageSize;
      return this.tableData.slice(start, end);
    },
  },
4、方法 (methods)
  • handleCurrentChange:当页码改变时触发,更新当前页码。
  • handleSizeChange:当每页条数改变时触发,更新每页条数据。
methods: {
    // 当前页改变
    handleCurrentChange(page) {
      this.currentPage = page;
    },
    
    // 每页条数改变
    handleSizeChange(val) {
        this.pageSize = val;
    },  
}

二、跨页选择

Element UI是一款基于Vue.js的组件库,广泛应用于Web开发。在某些场景下,我们需要实现跨页全选功能,即用户在第一页选择了某些项后,切换到第二页时这些项仍然被选中。下面是一个简单的实现方法。

在Element UI中,我们可以使用el-table组件来展示表格数据,并使用el-table-column组件来定义列。为了实现跨页全选功能,我们需要使用el-table-column组件的type='selection’属性来创建一个选择框列。

我们将所有选中的项存储在变量中。这样,即使用户切换到其他页面,这些选中的项也不会被清除。

1、模板部分 (<template>)
  • el-table绑定 row-key 属性
    行数据的 Key,用来优化 Table 的渲染;在使用 reserve-selection 功能与显示树形数据时,该属性是必填的。类型为 String 时,支持多层访问:user.info.id,但不支持 user.info[0].id,此种情况请使用 Function。

  • el-table绑定 selection-change 事件
    当选择项发生变化时会触发该事件

  • 为每一行添加一个选择框selection列
    实现多选非常简单: 手动添加一个el-table-column,设type属性为selection即可

  • 将selection列设置reserve-selection=true
    仅对 type=selection 的列有效,类型为 Boolean,为 true 则会在数据更新之后保留之前选中的数据(需指定 row-key)

<el-table :data="currentPageData" row-key="id" style="width: 100%"
      @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" :reserve-selection="true"></el-table-column>
      <el-table-column prop="id" label="id" width="180"></el-table-column>
      <el-table-column prop="name" label="Name" width="180"></el-table-column>
      <el-table-column prop="value" label="value"></el-table-column>
</el-table>
2、数据部分 (data)
  • 维护一个选中行的数组
    创建一个新的数组(例如selectedRows)来存储所有被选中的行的ID或唯一标识。这个数组将跨页存储所有选中的项。
data() {
    return {
      selectedRows: [],// 存储选中行的数组
    };
},
3、方法 (methods)
  • handleSelectionChange:当用户选中或取消选中某行时更新selectedItems数组
methods: {
    // 更新选中项的数组
    handleSelectionChange(val) {
      this.selectedRows = val.map(item => item);
    },
}

三、限制数量

在 Element UI 的 组件中,限制多选数量可以通过监听 selection-change 事件来实现。以下是一个详细的步骤和示例代码,展示了如何在 Vue 组件中限制 的多选数量。以及限制复选框CheckBox 是否可以勾选。

1、模板部分 (<template>)
  • 增加 selectable 属性
    仅对 type=selection 的列有效,类型为 Function,Function 的返回值用来决定这一行的 CheckBox 是否可以勾选

  • 增加 ref=“multipleTable”

<el-table :data="currentPageData" ref="multipleTable" row-key="id" style="width: 100%"
      @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" :reserve-selection="true"
        :selectable="isSelectable"></el-table-column>
      <el-table-column prop="id" label="id" width="180"></el-table-column>
      <el-table-column prop="name" label="Name" width="180"></el-table-column>
      <el-table-column prop="value" label="value"></el-table-column>
</el-table>
2、数据部分 (data)
  • 维护一个最大选择数量
data() {
    return {
      maxSelection: 15, // 最大选择数量
    };
},
3、方法 (methods)
  • handleSelectionChange:当用户选中或取消选中某行时更新selectedItems数组
    增加最大选择判断,如果点全选按钮,则截取数组,只取前面this.maxSelection条数据,多余部分取消选中

  • toggleSelection:取消选择

  • isSelectable:是否可选
    用来决定这一行的 CheckBox 是否可以勾选

methods: {
    // 判断是否超过最大选择数量
      if (val.length > this.maxSelection) {
        // 清除提示
        this.$message.closeAll()
        // 提示
        this.$message({
          message: `最多选择${this.maxSelection}条哦`,
          type: "warning"
        })
      }
      // 截取数组,只取前面this.maxSelection条数据
      let newArr = val.splice(0, this.maxSelection)
      // 更新选中行数组
      this.selectedRows = newArr.map(row => row);
      this.$nextTick(() => {
        // 取消选择
        this.toggleSelection(val)
      })
      
      // 取消选择
    toggleSelection(rows) {
      rows.forEach(row => {
        this.$refs.multipleTable.toggleRowSelection(row, false);
      });
    },

    // 是否可选
    isSelectable(row, index) {
      // 未超过最大选择条数
      if (this.selectedRows.length < this.maxSelection) {
        return true;
      } else {
        // 超过最大选择条数
        let ids = this.selectedRows.map((item) => item.id);
        //判断当前行的唯一标识符 id,是否存在于已选数组中
        if (ids.includes(row.id)) {
          // 已选择的行,可取消禁用
          return true;
        } else {
          // 超过最大选择条数,且当前行未被选中时,禁用
          return false;
        }
      }
    }
    
}

四、效果展示

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/917128.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ThriveX 博客管理系统前后端项目部署教程

前端 前端项目地址&#xff1a;https://github.com/LiuYuYang01/ThriveX-Blog 控制端项目地址&#xff1a;https://github.com/LiuYuYang01/ThriveX-Admin Vercel 首先以 Vercel 进行部署&#xff0c;两种方式部署都是一样的&#xff0c;我们以前端项目进行演示 首先我们先…

使用electron-egg把vue项目在linux Ubuntu环境下打包并安装运行

electron-egg一个入门简单、跨平台、企业级桌面软件开发框架https://www.kaka996.com/electron-egg 跳转地址 1,使用 git下载代码到本地,如果没有git需要进行安装 # gitee git clone https://gitee.com/dromara/electron-egg.git # github git clone https://github.com/dro…

力扣-Mysql-3322- 英超积分榜排名 III(中等)

一、题目来源 3322. 英超积分榜排名 III - 力扣&#xff08;LeetCode&#xff09; 二、数据表结构 表&#xff1a;SeasonStats --------------------------- | Column Name | Type | --------------------------- | season_id | int | | team_id …

深度学习基础—Beam search集束搜索

引言 深度学习基础—Seq2Seq模型https://blog.csdn.net/sniper_fandc/article/details/143781223?fromshareblogdetail&sharetypeblogdetail&sharerId143781223&sharereferPC&sharesourcesniper_fandc&sharefromfrom_link 上篇博客讲到&#xff0c;贪心算…

vueRouter路由切换时实现页面子元素动画效果, 左右两侧滑入滑出效果

说明 vue路由切换时&#xff0c;当前页面左侧和右侧容器分别从两侧滑出&#xff0c;新页面左右分别从两侧滑入 效果展示 路由切换-滑入滑出效果 难点和踩坑 现路由和新路由始终存在一个页面根容器&#xff0c;通过<transition>组件&#xff0c;效果只能对页面根容器有效…

【EasyExcel】复杂导出操作-自定义颜色样式等(版本3.1.x)

文章目录 前言一、自定义拦截器二、自定义操作1.自定义颜色2.合并单元格 三、复杂操作示例1.实体(使用了注解式样式)&#xff1a;2.自定义拦截器3.代码4.最终效果 前言 本文简单介绍阿里的EasyExcel的复杂导出操作&#xff0c;包括自定义样式&#xff0c;根据数据合并单元格等。…

集群搭建高可用

contos7.9 部署3节点 hadoop3.4 高可用集群 contos7.9 部署3节点 hadoop3.4 高可用集群环境信息Hadoop与Zookeeper的版本对应关系服务器角色分配使用端口服务器配置配置免密登录服务器配置初始化 init_server.sh配置主机名映射所有节点配置 hosts文件 hadoop 安装环境配置下载安…

Pycharm 配置 Poetry

Python 环境安装 参考以下&#xff1a; 官网安装步骤 CODA方式安装 Poetry 安装 Poetry在windows下的安装使用 1.下载软件包 下载地址 2.获取安装脚本下载地址 3.使用命令安装 打开cmd&#xff0c;进入安装包和脚本文件所在目录&#xff0c;执行命令&#xff1a; python …

卡尔曼滤波:从理论到应用的简介

卡尔曼滤波&#xff08;Kalman Filter&#xff09;是一种递归算法&#xff0c;用于对一系列噪声观测数据进行动态系统状态估计。它广泛应用于导航、控制系统、信号处理、金融预测等多个领域。本文将介绍卡尔曼滤波的基本原理、核心公式和应用案例。 1. 什么是卡尔曼滤波&#x…

聊聊Flink:Flink的运行时架构

一、运行时架构 上一篇我们可以看到Flink的核心组件的Deploy层&#xff0c;该层主要涉及了Flink的部署模式&#xff0c;Flink支持多种部署模式&#xff1a;本地、集群&#xff08;Standalone/YARN&#xff09;、云&#xff08;GCE/EC2&#xff09;。 Local&#xff08;本地&am…

元器件封装

元器件封装类型 为什么越来越多用贴片元件&#xff0c;而不是插件元件 为什么越来越多用贴片元件&#xff0c;而不是插件元件 1.体积小、质量小、容易保存和运输&#xff1b; 2.容易焊接和拆卸。抗震效果好。 贴片元件不用过孔&#xff0c;用锡少。直插元件最麻烦的就是拆卸&a…

[JAVAEE] 网络编程

目录 一. 什么是socket套接字 二. socket套接字 2.1 socket套接字根据传输层协议分类 2.2 TCP流套接字 UDP数据报套接字主要特点 三. UDP数据报套接字编程 3.1 DatagramSocket 是UDP socket, 用于发送和接受数据报 3.2 DatagramPacket 是UDP socket 发送和接收的数据报 …

GNN入门案例——KarateClub结点分类

文章目录 一、任务描述二、环境配置三、加载数据四、定义网络结构五、训练模型 一、任务描述 Karate Club 图任务是一个经典的图结构学习问题&#xff0c;通常用于社交网络分析和社区检测。该数据集是由 Wayne W. Zachary 在1977年收集的&#xff0c;描述了一个美国的空手道俱…

173. 二叉搜索树迭代器【 力扣(LeetCode) 】

文章目录 零、原题链接一、题目描述二、测试用例三、解题思路四、参考代码 零、原题链接 173. 二叉搜索树迭代器 一、题目描述 实现一个二叉搜索树迭代器类BSTIterator &#xff0c;表示一个按中序遍历二叉搜索树&#xff08;BST&#xff09;的迭代器&#xff1a; BSTIterato…

【lamafactory BLEU ROUGLE L评测】

1、BLEU/ROUGLE评测界面 2、这个是用BLEU 和ROUGL来评测 目录&#xff1a;saves/Qwen2-7B-Chat/lora/eval_2024-11-14-16-28-19/ 在saves文件夹 生成的文件如下 all_results.json文件 说明模型在这个测试集上是不好的 3、可以查看预测结果的文件 predict_result.json

前端开发中常用的包管理器(npm、yarn、pnpm、bower、parcel)

文章目录 1. npm (Node Package Manager)2. Yarn (Yarn Package Manager)3. pnpm4. Bower5. Parcel总结 前端开发中常用的包管理器主要有以下几个&#xff1a; 1. npm (Node Package Manager) 简介&#xff1a; npm 是 Node.js 的默认包管理器&#xff0c;也是最广泛使用的包…

Python爬虫项目 | 一、网易云音乐热歌榜歌曲

文章目录 1.文章概要1.1 实现方法1.2 实现代码1.3 最终效果 2.具体讲解2.1 使用的Python库2.2 代码说明2.2.1 创建目录保存文件2.2.2 爬取网易云音乐热歌榜单歌曲 2.3 过程展示 3 总结 1.文章概要 学习Python爬虫知识&#xff0c;实现简单的一个小案例&#xff0c;网易云音乐热…

SHELL脚本(Linux)

声明 学习视频来自 B 站UP主泷羽sec&#xff0c;如涉及侵权马上删除文章。 笔记的只是方便各位师傅学习知识&#xff0c;以下网站只涉及学习内容&#xff0c;其他的都与本人无关&#xff0c;切莫逾越法律红线&#xff0c;否则后果自负。 ✍&#x1f3fb;作者简介&#xff1a;致…

reduce-scatter:适合分布式计算;Reduce、LayerNorm和Broadcast算子的执行顺序对计算结果的影响,以及它们对资源消耗的影响

目录 Gather Scatter Reduce reduce-scatter:适合分布式计算 Reduce、LayerNorm和Broadcast算子的执行顺序对计算结果的影响,以及它们对资源消耗的影响 计算结果理论正确性 资源消耗方面 Gather 这个也很好理解,就是把多个进程的数据拼凑在一起。 Scatter 不同于Br…

arkUI:水果选择与管理:基于 ArkUI 的长按编辑功能实现

水果选择与管理&#xff1a;基于 ArkUI 的长按编辑功能实现 1 主要内容说明2 相关内容2.1 相关内容2.1.1 源码1内容的相关说明2.1.1.1 数据结构与状态管理2.1.1.2 添加水果功能2.1.1.3 水果列表展示2.1.1.4 长按进入编辑模式2.1.1.5 复选框的多选功能2.1.1.6 删除水果功能2.1.1…