vue+elementui实现下拉表格多选+搜索+分页+回显+全选2.0

一、vue+elementui实现下拉表格多选+搜索1.0

二、vue+elementui实现下拉表格多选+搜索+分页+回显+全选2.0

在1.0的基础上,终于可以实现在下拉框表格分页的前提下不同页码的回显辣,分页是前端来分页的(代码略乱且没有封装还很长,随便看看吧)

在这里插入图片描述
在这里插入图片描述

1、在使用之前首先要安装Element-ui

1-1、template

<template>
  <div class="goodsindex">
    <div class="allBox" v-loading="isloading">
      <el-select
        id="equBox"
        ref="select"
        clearable
        multiple
        v-model="group.equIdList"
        placeholder="请选择设备"
        @change="handleEquId"
        @click.native="deptogglePanel($event)"
      >
        <el-option
          v-for="(item, i) in group.pageAllList"
          :key="i"
          :label="item.equNumber"
          :value="item.equId"
        ></el-option>
      </el-select>
      <div
        v-if="group.showTree"
        class="treeDiv"
        id="treeDiv"
        ref="tableList"
        :style="{ top: group.equBoxTop + 'px' }"
      >
        <div class="equSElect">
          <el-input
            v-model="group.name"
            clearable
            size="mini"
            style="margin-right: 15px; width: 50%"
            placeholder="设备编码/名称"
            @keyup.enter.native="select"
          ></el-input>
          <el-button type="primary" size="mini" @click="select">搜索</el-button>
        </div>
        <!-- 检索结果 -->
        <el-table
          :data="group.pageList"
          border
          size="mini"
          style="margin: 10px 0"
          ref="multipleTable"
          id="multipleTable"
          row-key="equId"
          @row-click="handleRegionNodeClick"
          @select="handleCheckBox"
          @select-all="handleSelectAll"
          @selection-change="selectionChangeHandle"
        >
          <el-table-column
            type="selection"
            header-align="center"
            align="center"
            width="50"
          >
          </el-table-column>
          <el-table-column
            prop="equNumber"
            header-align="center"
            align="center"
            label="设备编码"
            min-width="180"
          >
          </el-table-column>
          <el-table-column
            prop="equName"
            header-align="center"
            align="center"
            label="设备名称"
            min-width="180"
          >
          </el-table-column>
        </el-table>
        <!-- 分页 -->
        <el-pagination
          background
          @size-change="handleSizeChange"
          @current-change="handleCurrentChange"
          :current-page="group.currentPage"
          :page-size="group.pageSize"
          layout="total, prev, pager, next"
          :total="group.totalPage"
        >
        </el-pagination>
      </div>
    </div>
  </div>
</template>

1-2、script

export default {
  data() {
    return {
      isShowSelect: true, //隐藏select本来的下拉框
      group: {
        name: "",// 搜索
        pageAllList: [], // 下拉框数据
        pageList: [], // 表格数据
        showTree: false, // 表格显示隐藏
        isbg: false, //整体背景
        equIdList: [],// 下拉框选中数据
        multipleSelection: [], // 表格选中数据
        equBoxTop: 46,// 表格原始定位top
        currentPage: 1,
        pageSize: 8, 
        totalPage: 0,
      },
    };
  },
  computed: {},
  watch: {
    isShowSelect(val) {
      // 隐藏select自带的下拉框
      this.$refs.select.blur();
    },
  },
 async created() {
   await this.getSelectList();
   await this.getDataList();
   await this.getPage(this.equIdList);
  },
  methods: {
    //下面的方法是进行设置行标识key的方法
    getRowKeys(row) {
      return row.equId;
    },
    //设备
    handleEquId(val) {
      this.group.multipleSelection = val;
      this.getDataList();
    },
    // 分页
    handleSizeChange(val) {
      this.group.pageSize = val;
      this.getDataList();
    },
    // 分页
    handleCurrentChange(val) {
      this.group.currentPage = val;
      this.getDataList();
    },
    //搜素
    select() {
      this.group.currentPage = 1;
      this.getDataList();
    },
    // 设备下拉选获取选中页数 回显的时候计算出第一条数据在那一页
    async getPage(equInfoIds) {
      let equId = equInfoIds;
      let pageIndex = 0;
      let pageIndexArr = [];
      for (let i in this.group.pageAllList) {
        for (let j in equId) {
          if (equId[j] == this.group.pageAllList[i].equId) {
            pageIndex = Math.floor(i / this.group.pageSize) + 1;
            if (i == 0) {
              pageIndex = 1; // 如果是第一条数据,它在第一页
            }
            pageIndexArr.push(pageIndex);
          }
        }
      }
      const uniqueArr = Array.from(new Set(pageIndexArr));
      this.group.currentPage = uniqueArr[0];
      // console.log("那一页", uniqueArr);
      await this.getDataList();
    },
    //获取表格列表
    async getDataList() {
      this.isloading = true;
      await this.Sevice({
        url: "/select",
        method: "post",
        params: {
          name: this.group.name,
        },
      })
        .then((res) => {
          if (res && res.code == 200) {
          // res.select的数据类型 [{equId:1,equNumber:2,equName:3}]
            this.group.pageList = res.select;
            this.group.pageList = this.group.pageList.slice(
              (this.group.currentPage - 1) * this.group.pageSize,
              this.group.currentPage * this.group.pageSize
            );
            this.group.totalPage = res.select.length;
            this.$nextTick(() => {
              if (this.$refs.multipleTable) {
                this.group.pageList.forEach((item, index) => {
                  if (
                    this.group.multipleSelection.findIndex(
                      (v) => v == item.equId
                    ) >= 0
                  ) {
                    this.$refs.multipleTable.toggleRowSelection(
                      this.$refs.multipleTable.data[index],
                      true
                    );
                  }
                });
              }
            });
            // console.log("multipleSelection", this.multipleSelection);
          } else {
            this.group.pageList = [];
            this.group.totalPage = 0;
          }
        })
        .catch((err) => {
          console.log(err);
        });
      this.isloading = false;
    },
    // 下拉框列表(因为有接口有搜索,所以下拉框和表格分两个接口获取)
    async getSelectList() {
      this.isloading = true;
      await this.Sevice({
        url: "/select",
        method: "post",
      })
        .then((res) => {
          if (res && res.code == 200) {
          // res.select的数据类型 [{equId:1,equNumber:2,equName:3}]
            this.group.pageAllList = res.select;
          }
        })
        .catch((err) => {
          console.log(err);
        });
      this.isloading = false;
    },
    // 多选
    selectionChangeHandle(val) {
      this.showTree = true;
    },
    //该方法是单选时的方法
    handleCheckBox(rows, row) {
      this.showTree = true;
      if (this.group.multipleSelection.find((item) => item == row.equId)) {
        //下面这个filter方法就是删除的方法
        this.group.multipleSelection = this.group.multipleSelection.filter(
          (item) => item != row.equId
        );
      } else {
        this.group.multipleSelection.push(row.equId);
      }
      // console.log("选中id2:", this.group.multipleSelection);
      this.group.equIdList = this.group.multipleSelection;
    },
    //该方法是当页全选的方法
    handleSelectAll(rows) {
      this.showTree = true;
      if (rows.length) {
        rows.forEach((row) => {
          if (!this.group.multipleSelection.find((item) => item == row.equId)) {
            this.group.multipleSelection.push(row.equId);
          }
        });
      } else {
        this.group.pageList.forEach((row) => {
          this.group.multipleSelection = this.group.multipleSelection.filter(
            (item) => item != row.equId
          );
        });
      }
      // console.log("选中id1:", this.group.multipleSelection);
      this.group.equIdList = this.group.multipleSelection;
    },
    // 点击input 阻止冒泡 控制table显示隐藏
    async deptogglePanel(event) {
      // console.log(event);
      this.group.isbg = true;
      this.isShowSelect = !this.isShowSelect; //隐藏select本来的下拉框
      event || (event = window.event);
      event.stopPropagation
        ? await event.stopPropagation()
        : (event.cancelBubble = true);
      this.group.showTree ? await this.tableHide() : await this.tableShow();
      await this.getDataList();
    },
    //隐藏表格
    async tableHide() {
      this.group.showTree = false;
      await document.addEventListener("click", this.tableHideList, false);
    },
    //显示表格
    async tableShow() {
      this.group.showTree = true;
      await document.addEventListener("click", this.tableHideList, false);
      this.$nextTick(() => {
        let equBox = document.getElementById("equBox").offsetHeight;
        this.group.equBoxTop = equBox + 10; // 表格的高度定位,应该按照所选择的
      });
    },
    async tableHideList(e) {
      let that = this;
      that.$nextTick(async () => {
        let multipleTable = document.getElementById("treeDiv");
        if (multipleTable && !multipleTable.contains(e.target)) {
          await that.tableHide();
        }
      });
    },
    // 点击table节点
    async handleRegionNodeClick() {
      this.showTree = true;
    },
  },
};
</script>

1-3、style

<style scoped>
.allBox {
  position: relative;
  width: 100%;
}
.equSElect {
  display: flex;
}
.treeDiv {
  position: absolute;
  top: 46px;
  z-index: 9999999 !important;
  width: calc(100% - 20px);
  overflow: auto;
  max-height: 390px;
  border-radius: 6px;
  background: #ffffff;
  padding: 8px 10px;
  box-shadow: 0 5px 5px #cccbcb;
  border: 1px solid #e6e5e5;
  margin: 0 10px;
}

.treeDiv::-webkit-scrollbar {
  /*滚动条整体样式*/
  width: 4px;
  /*高宽分别对应横竖滚动条的尺寸*/
  height: 4px;
}

.treeDiv::-webkit-scrollbar-thumb {
  /*滚动条里面小方块*/
  border-radius: 5px;
  -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
  background: rgba(0, 0, 0, 0.2);
}

.treeDiv::-webkit-scrollbar-track {
  /*滚动条里面轨道*/
  -webkit-box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.2);
  border-radius: 0;
  background: rgba(0, 0, 0, 0.1);
}

.treeDiv .el-table {
  font-size: 14px;
}

.treeDiv .el-table /deep/ td {
  padding: 4px 0;
}
</style>

2、完结撒花(后期我一定会封装的 立个flag)

请添加图片描述

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

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

相关文章

被裁20240927 --- 嵌入式硬件开发 前篇

前篇主要介绍一些相关的概念&#xff0c;用于常识扫盲&#xff0c;后篇开始上干货&#xff01; 他捧着一只碗吃过百家的饭 1. 处理器芯片1.1 处理器芯片制造商一、 英特尔&#xff08;Intel&#xff09;二、 三星&#xff08;SAMSUNG&#xff09;三、 高通&#xff08;Qualcomm…

【Web】2024“国城杯”网络安全挑战大赛决赛题解(全)

最近在忙联通的安全准入测试&#xff0c;很少有时间看CTF了&#xff0c;今晚抽点时间回顾下上周线下的题(期末还没开始复习&#x1f622;) 感觉做渗透测试一半的时间在和甲方掰扯&水垃圾洞&#xff0c;没啥惊喜感&#xff0c;还是CTF有意思 目录 Mountain ez_zhuawa 图…

高阶:基于Python paddleocr库 提取pdf 文档高亮显示的内容

预览 第1步&#xff1a;理解基本结构和导入必要的库 # 1. 首先导入需要的库 import os # 用于处理文件和路径 import cv2 # 用于图像处理 import numpy as np # 用于数值计算 from paddleocr import PaddleOCR # 用于文字识别 from pdf2image import convert_from_path #…

保护模式基本概念

CPU 架构 RISC&#xff08;Reduced Instruction Set Computer&#xff09; 中文即"精简指令集计算机”。RISC构架的指令格式和长度通常是固定的&#xff08;如ARM是32位的指令&#xff09;、且指令和寻址方式少而简单、大多数指令在一个周期内就可以执行完毕 CISC&…

@vue/cli启动异常:ENOENT: no such file or directory, scandir

参考:https://blog.csdn.net/qq_44355188/article/details/122239566 首先异常报错是&#xff1a;ENOENT: no such file or directory, scandir ‘D:\Data\Project\VueProject\hello\node_modulesvue\cli-plugin-eslint\locales’&#xff1b;我的vue/cli版本是 4.5.15 重点是…

全视通物联数据中台解决方案助力智慧医院新时代

全国医院物联网大会系列活动暨【行走的课堂】标杆研学 四川站“医院物联网应用创新经验交流会”&#xff0c;近日在成都召开。珠海全视通信息技术有限公司总经理林三朝以《物联网技术助力医院高质量发展》为题做了精彩演讲。林总就物联网技术如何助力医院高质量发展&#xff0c…

QT程序发布后,mysql在其它电脑设备无法连接数据库

QT程序发布后&#xff0c;mysql在其它电脑设备无法连接数据库 D:\mysql-5.7.24-winx64\lib, mysql-5.7.24-winx64是一个压缩包&#xff0c;用于启动mysql服务&#xff0c;创建数据库 压缩包 解决方法&#xff1a; 拷贝库到exe的相同目录&#xff0c;libmysql.dll,libmysql.li…

vulnhub靶场-matrix-breakout-2-morpheus攻略(截止至获取shell)

扫描出ip为192.168.121.161 访问该ip&#xff0c;发现只是一个静态页面什么也没有 使用dir dirsearch 御剑都只能扫描到/robots.txt /server-status 两个页面&#xff0c;前者提示我们什么也没有&#xff0c;后面两个没有权限访问 扫描端口&#xff0c;存在81端口 访问&#x…

CNN、RNN、LSTM和Transformer之间的区别和联系

文章目录 CNN、RNN、LSTM和Transformer之间的区别和联系前言CNN&#xff08;卷积神经网络&#xff09;RNN&#xff08;循环神经网络&#xff09;LSTM&#xff08;长短期记忆网络&#xff09;Transformer四者之间的联系与区别Yolo算法简介Yolo和CNN的关系YOLO各版本 CNN、RNN、L…

f(f(x))=x^2 -11x+36, 求f(6)的值,

偶然看到的一个题目&#xff0c;一时兴起&#xff0c;做了一下。题目如下 简单粗暴的思路是待定系数法&#xff0c;盲猜f(x)是个2次函数&#xff0c;令f(x)ax^2bxc ,带入原式&#xff0c;发现矛盾&#xff08;计算略&#xff09;就想放弃了。 忽然看到如果带入6 的话&#xf…

微软远程桌面APP怎么用

微软远程桌面&#xff08;Remote Desktop&#xff09;客户端&#xff08;RD Client&#xff09;是一款由微软开发的应用程序&#xff0c;允许用户通过网络连接远程访问和控制另一台计算机。同时&#xff0c;微软远程桌面RD Client支持多种设备和操作系统&#xff0c;包括Window…

美国加州房价数据分析01

1.项目简介 本数据分析项目目的是分析美国加州房价数据&#xff0c;预测房价中值。 环境要求&#xff1a; ancondajupyter notebookpython3.10.10 虚拟环境&#xff1a; pandas 2.1.1 numpy 1.26.1 matplotlib 3.8.0 scikit-learn1.3.1 2. 导入并探索数据集 通用的数据分析…

PPO算法基础(一)

PPO近端策略优化算法 我们今天还是主要来理解PPO算法的数学原理。PPO是一种策略梯度方法&#xff0c;简单的策略梯度对每个样本&#xff08;或者一组样本&#xff09;进行一次梯度更新&#xff0c;对单个样本执行多个梯度步骤会导致一些问题&#xff0c;因为梯度偏差太大&…

LabVIEW软件开发的未来趋势

LabVIEW软件开发的未来趋势可以从以下几个方面来分析&#xff1a; ​ 1. 与AI和机器学习的深度结合 趋势&#xff1a;LabVIEW正在向集成AI和机器学习方向发展&#xff0c;尤其是在数据处理、预测性维护和自动化控制领域。 原因&#xff1a;AI技术的普及使得实验和工业场景中的…

H3C MPLS跨域optionB

实验拓扑 实验需求 如图,VPN1 和 VPN2 分别通过运营商 MPLS VPN 连接各自分支机构按照图示配置 IP 地址,VPN1 和 VPN2 连接同一个 PE 设备的私网 IP 网段存在地址复用,使用多 VRF 技术来防止 IP 冲突AS 100 和 AS 200 内部的公共网络中各自运行 OSPF 使 AS 内各设备的 Loo…

【数据结构练习题】链表与LinkedList

顺序表与链表LinkedList 选择题链表面试题1. 删除链表中等于给定值 val 的所有节点。2. 反转一个单链表。3. 给定一个带有头结点 head 的非空单链表&#xff0c;返回链表的中间结点。如果有两个中间结点&#xff0c;则返回第二个中间结点。4. 输入一个链表&#xff0c;输出该链…

细说STM32F407单片机轮询方式读写SPI FLASH W25Q16BV

目录 一、工程配置 1、时钟、DEBUG 2、GPIO 3、SPI2 4、USART6 5、NVIC 二、软件设计 1、FALSH &#xff08;1&#xff09;w25flash.h &#xff08;2&#xff09; w25flash.c 1&#xff09;W25Q16基本操作指令 2&#xff09;计算地址的辅助功能函数 3&#xff09;器…

框架程序设计-简答以及论述

目录 maven的pom作用&#xff1a; Pointcut("execution(*com.example.dome.*.*(……))") 缓存的作用&#xff0c;redis配置过程 Redis配置过程&#xff1a; SpringBoot缓存配置过程&#xff1a; AOP的五种增强注解&#xff1a; 论述题&#xff1a;包结构作用、…

如何在谷歌浏览器中启用语音搜索

想象一下&#xff0c;你正在拥挤的地铁上&#xff0c;双手都拿着沉重的购物袋&#xff0c;突然你想搜索附近的咖啡馆。此时如果你能通过语音而不是打字来进行搜索&#xff0c;那将多么的便利&#xff01;在谷歌浏览器中&#xff0c;启用语音搜索功能就是这么简单而高效&#xf…

C语言从入门到放弃教程

C语言从入门到放弃 1. 介绍1.1 特点1.2 历史与发展1.3 应用领域 2. 安装2.1 编译器安装2.2 编辑器安装 3. 第一个程序1. 包含头文件2. 主函数定义3. 打印语句4. 返回值 4. 基础语法4.1 注释4.1.1 单行注释4.1.2 多行注释 4.2 关键字4.2.1 C语言标准4.2.2 C89/C90关键字&#xf…