【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现

这篇具有很好参考价值的文章主要介绍了【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


学习目标

  • vue列表过滤
  • el-table的理解

1、el-table表格的理解

先来看一段代码:

el-table-column prop="warehouseName" label="库房" :show-overflow-tooltip="true" header-align="left" align="left">
        <template slot-scope="scope">
            {{scope.row.warehouseName}}
        </template>
        <template slot="header" slot-scope="scope">
            <el-row :span="24">
                <el-col :span="6" class="custom-title"
                    style="padding-top: 5px;color:rgb(12, 123, 164); font-size:12px;line-height: 2;">库房</el-col>
                <el-col :span="18" class="search-before-content">
                    <el-input v-model="search" size="mini" placeholder="输入关键字搜索" />
                </el-col>
            </el-row>
            <hr class="hr-custom-style" />
        </template>
    </el-table-column>

chatGPT的理解真的很6:

这段代码使用了 Element UI 的组件,创建了一个表格列组件 el-table-column,并为它设置了一些属性和插槽。

各种属性:
名称 作用
prop 指定了该列绑定的数据对象的属性名为 warehouseName
label 指定了该列的列名为 “库房”
show-overflow-tooltip 表示当单元格内容过长时,是否显示 tooltip 提示框
header-align 表示表头的对齐方式
align 属性表示该列单元格内容的对齐方式,本例中设置为左对齐
  • <template slot-scope="scope"> 定义了一个数据对象的插槽,用于渲染每个单元格的数据内容。
  • 在插槽内部使用了 Mustache 语法,定了scope.row.warehouseName 属性,表示该列的数据来自于数据对象中的 warehouseName 属性。
  • <template slot="header" slot-scope="scope"> 定义了表头的插槽,用于自定义表头的内容。在插槽内部使用了 Element UI 的 Grid 组件,将表头分成两列,左侧是 “库房” 的文本,右侧是一个搜索框。
  • v-model 指令绑定了 search 变量,表示搜索框中的文本输入。此外,还插入了一条横线作为装饰。
问题总结:

我最开始的搜索框一直显示不了我输进去的文字,搞了半天才发现是因为我搞了一个eslint检查,关了之后就发现好了。当然这个问题比较小众。因为这个检查,我之前把这个插槽给删了,所以数据就显示不上去。【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现


2、列表过滤

首先需要明确的是,这个功能的实现是要用到computed计算属性的。

第一步

写好计算属性的代码:

 computed: {
    tables() {
      const search = this.search;
      console.log(search);
      if (search) {
        return this.tableData.filter((data) => {
          return Object.keys(data).some((key) => {
            return String(data[key]).toLowerCase().indexOf(search) > -1;
          });
        });
      }
      return this.tableData;
    },
  },
代码解释:
  • 首先从组件实例的data中获取搜索条件search。

  • 如果搜索条件不为空,使用filter()方法对表格数据进行筛选,筛选出符合条件的数据组成一个新的数组并返回。

  • filter()方法的回调函数接收一个data参数,该参数表示表格数据数组中的每一个数据项。

  • Object.keys(data)可以获取到data对象的所有属性名组成的数组,some()方法用于检测数组中的元素是否满足指定条件。

  • some()方法的回调函数接收一个key参数,表示data对象的每个属性名。String(data[key])可以将属性值转为字符串类型,然后使用toLowerCase()方法将其转为小写,最后使用indexOf()方法查找是否包含搜索条件。

  • 如果符合条件,则some()方法返回true,filter()方法将该数据项加入到新数组中。

  • 如果不符合条件,则some()方法返回false,filter()方法不会将该数据项加入到新数组中。

  • 如果搜索条件为空,直接返回表格数据数组。

经典疑问:

其实看了这段代码对前端小白来说还是很有挑战的。因此我想再深入记录几个问题。

  • 为什么要用箭头函数?
    箭头函数的作用就是为了避免this的指向问题
  • JavaScript 中,每个函数都有自己的作用域。当函数被定义时,它会创建一个新的作用域,该作用域包含了函数内部的所有变量和函数声明。这个作用域就是“定义时所在的作用域”。
  • 箭头函数中,它的 this 始终指向的是该函数定义时所在的作用域中的 this,而不是调用时所在的作用域中的 this。这是因为箭头函数没有自己的 this 绑定,它继承了它定义时所在作用域中的 this。

在该代码中,箭头函数作为 filter() 方法的参数,它的 this 值继承自外部作用域(即 tables() 函数的 this 值),而不是 filter() 方法本身的 this 值。这意味着箭头函数内部的 this 值与 tables() 函数相同,可以访问该函数作用域中的变量,比如 searchtableData


为什么要返回-1?
在这段代码中,indexOf() 方法用于查找一个指定字符或字符串在另一个字符串中首次出现的位置,如果找到,则返回其在字符串中的索引位置;如果未找到,则返回-1。
在上述代码中,indexOf() 方法用于判断 search 是否在当前数据项的每个属性值中出现过。如果 search 未出现在当前数据项的任何属性值中,则返回值为-1,否则返回值为首次出现的索引位置。由于 indexOf() 返回的是数字类型。

因此在这段代码中,我们可以使用 > -1 来判断 search 是否在当前数据项中出现过,而不必关心具体的索引值。


第二步

把el-table的数据来源改为计算属性 table

【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现文章来源地址https://www.toymoban.com/news/detail-500093.html


我的代码:
<template>
  <div>
    <el-table
      :data="tables.slice((currentPage-1)*pageSize,currentPage*pageSize)"
      style="width: 100%"
    >
      <el-table-column
        label="日期"
        width="180"
      >
        <template slot-scope="scope">
          <i class="el-icon-time"></i>
          <span style="margin-left: 10px">{{ scope.row.date}}</span>
        </template>
      </el-table-column>
      <el-table-column
        label="姓名"
        width="180"
      >
        <template slot-scope="scope">
          <el-popover
            trigger="click"
            placement="top"
          >
            <p>姓名: {{ scope.row.name }}</p>
            <p>住址: {{ scope.row.address }}</p>
            <div
              slot="reference"
              class="name-wrapper"
            >
              <el-tag size="medium">{{ scope.row.name }}</el-tag>
            </div>
          </el-popover>
        </template>
      </el-table-column>
      <el-table-column label="操作">
        <template slot-scope="scope">
          <el-button
            size="mini"
            @click="handleEdit(scope.$index, scope.row)"
          >编辑</el-button>
          <el-button
            size="mini"
            type="danger"
            @click="handleDelete(scope.$index, scope.row)"
          >删除</el-button>
        </template>
      </el-table-column>

      <el-table-column align="right">
        <template
          slot="header"
          slot-scope="scope"
        >
          <el-input
            v-model="search"
            size="medium"
          />

        </template>
        <template slot-scope="scope">
          <el-button
            size="mini"
            @click="handleEdit(scope.$index, scope.row)"
          >Edit</el-button>
          <el-button
            size="mini"
            type="danger"
            @click="handleDelete(scope.$index, scope.row)"
          >Delete</el-button>
        </template>
      </el-table-column>
    </el-table>
    <!-- <el-pagination
      background
      layout="prev, pager, next"
      :total="1000"
    > -->
    <el-pagination
      align='center'
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="currentPage"
      :page-sizes="[1,5,10,20]"
      :page-size="pageSize"
      layout="total, sizes, prev, pager, next, jumper"
      :total="tableData.length"
    >
    </el-pagination>
    <!-- 
    </el-pagination> -->
  </div>
</template>
<script>
export default {
  name: "tableTest",
  data() {
    return {
      currentPage: 1,
      pageSize: 5,
      search: "",
      tableData: [
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-04",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1517 弄",
        },
        {
          date: "2016-05-01",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1519 弄",
        },
        {
          date: "2016-05-03",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1516 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },

        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "汤小单",
          address: "上海市普陀区金沙江路 1518 弄",
        },

        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
        {
          date: "2016-05-02",
          name: "王小虎",
          address: "上海市普陀区金沙江路 1518 弄",
        },
      ],
    };
  },
  methods: {
    handleEdit(index, row) {
      console.log(index, row);
    },
    handleDelete(index, row) {
      console.log(index, row);
    },
    //每页条数改变时触发 选择一页显示多少行
    handleSizeChange(val) {
      console.log(`每页 ${val}`);
      this.currentPage = 1;
      this.pageSize = val;
    },
    //当前页改变时触发 跳转其他页
    handleCurrentChange(val) {
      console.log(`当前页: ${val}`);
      this.currentPage = val;
    },
    onInput() {
      this.$forceUpdate();
    },
  },
  computed: {
    tables() {
      const search = this.search;
      console.log(search);
      if (search) {
        return this.tableData.filter((data) => {
          return Object.keys(data).some((key) => {
            return String(data[key]).toLowerCase().indexOf(search) > -1;
          });
        });
      }
      return this.tableData;
    },
  },
};
</script>
<style scoped>
</style>

到了这里,关于【详解|彻底搞懂el-table和列表过滤】vue列表过滤和el-table的实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue封装el-table表格组件

    先上效果图: 本文包含了具名插槽、作用域插槽、jsx语法三种: Render.vue( 很重要,必须有 ): Table.vue 使用Table组件

    2024年02月20日
    浏览(41)
  • Vue3 el-table 单选

    解决方式:给每个表格加上唯一key值

    2024年02月11日
    浏览(52)
  • vue el-table实现动态表头

    众所周知,element-ui中有一个表格组件el-table,用于展示多条结构类似的数据。之前遇到过一个需求,要手动控制el-table的表头显示。就是假如table表格一共有10列数据,可以通过设置勾选,决定显示多少列。 为了代码的复用性,将配置页面单独抽成了组件,所以代码中会有组件

    2024年02月12日
    浏览(53)
  • JavaWeb过滤器(Filter)详解,是时候该把过滤器彻底搞懂了(万字说明)

            注意:这篇文章很长,学习完后将会解决你对于过滤器(Filter)的所有疑惑,下面将通过理论和代码的结合来进行讲解演示.....    目录 基本介绍 过滤器原理 过滤器(Filter)接口 使用过滤器(Filter) 创建过滤器(Fliter) 使用过滤器(Filter) 配置过滤器(Filter)拦截路径  注解方式

    2024年02月02日
    浏览(41)
  • vue el-table 多选框回填

    主要代码: 效果: html js

    2024年01月18日
    浏览(47)
  • vue+el-table实现展开与折叠

    本文会提到两种实现方法,之前我使用的是第一种,后来加了固定列,发现展开与折叠失效,故而出现了第二种方法。 一、通过class名称获取节点,并对节点进行操作(该方法表格添加固定列会失效) 1.全部展开 2.全部折叠 二、通过el-table中的 toggleRowSelection方法来实现展开与

    2024年02月14日
    浏览(47)
  • vue模拟el-table演示插槽用法

    很多人知道插槽分为三种,但是实际到elementui当中为什么这么用,就一脸懵逼,接下来就跟大家聊一聊插槽在elementui中的应用,并且自己写一个类似el-table的组件 vue的slot分为三种::匿名插槽,具名插槽, 作用域插槽,主要作用:让父组件可以向子组件指定位置插入 html 结构

    2024年02月06日
    浏览(36)
  • vue+elementUI el-table实现单选

    2024年02月09日
    浏览(43)
  • 【vue】el-table实现动态添加行和列

    实现思路: 最近遇到一个动态增加行和列的需求,本来拿到需求的时候想用el-table中自带的方法去实现的,但是经过尝试发现不能满足想要实现的需求。没办法只能在el-table的基础上自己写原生。 大概思路如下: 1.首先把table中需要动态增加的行和列分开,分别定义一个数组

    2024年02月11日
    浏览(45)
  • vue + el-table点击表头改变其当前样式

    废话不多说,先看效果: 网上找了一大圈没有符合的,只能自己看着搞: 直接贴代码: 这种写法经使用过程中发现问题,故修改为以下:

    2024年02月13日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包