#独家
如何实现输入框和表格的联动,实现输入框输入内容查询表格数据?

2023-07-14 0 4,165

ui:

<template>
  <div>
    <el-breadcrumb separator-class="el-icon-arrow-right">
      <el-breadcrumb-item :to="{ path: '/searchone' }">查询数据</el-breadcrumb-item>
      <el-breadcrumb-item>查询数据表1</el-breadcrumb-item>
      <el-breadcrumb-item>查询数据表2</el-breadcrumb-item>
    </el-breadcrumb>
    <el-card>
      <!-- 搜索与添加区域 -->
      <el-row :gutter="20">
        <el-col :span="8">
          <el-input placeholder="请输入查询内容" v-model="inputContent" type="text">
            <el-button slot="append" icon="el-icon-search" @click="searchinput"></el-button>
          </el-input>
        </el-col>
      </el-row>

      <!-- 表格区域 -->
      <el-table :data="allData" border stripe>
        <el-table-column type="index" label="#"></el-table-column>
        <el-table-column v-for="(item, index) in columnList" :key="index" :prop="item.prop"
          :label="item.label"></el-table-column>
      </el-table>
    </el-card>
  </div>
</template>

js

<script>
export default {
  data () {
    return {
      inputContent: '',
      searchContent: '',
      allData: [],
      columnList: []
    }
  },
  created () {
    this.getAllData()
    this.getColumnList()
  },
  computed: {
    tables () {
      const search = this.searchContent
      if (this.inputContent === '') {
        // eslint-disable-next-line vue/no-side-effects-in-computed-properties
        this.searchContent = ''
        return this.allData
      }
      if (search !== '') {
        // eslint-disable-next-line no-return-assign
        return [this.allData.filter((dataNews) => {
          return Object.keys(dataNews).some((key) => {
            return String(dataNews[key]).toLowerCase().indexOf(search) > -1
          })
        }),
        // eslint-disable-next-line vue/no-side-effects-in-computed-properties
        this.count = this.allData.filter((dataNews) => {
          return Object.keys(dataNews).some((key) => {
            return String(dataNews[key]).toLowerCase().indexOf(search) > -1
          })
        }).length]
      }
      return this.allData
    }
  },
  methods: {
    getAllData () {
      // const { data: res } = await this.$http.get('')
      const data = [
        { name: '11', age: '11', city: '11' },
        { name: '12', age: '12', city: '12' },
        { name: '13', age: '13', city: '13' },
        { name: '14', age: '14', city: '14' },
        { name: '15', age: '15', city: '15' },
        { name: '16', age: '16', city: '16' }
      ]
      this.allData = data
    },
    getColumnList () {
      const prop = [
        { prop: 'name', label: '姓名' },
        { prop: 'age', label: '年龄' },
        { prop: 'city', label: '城市' }
      ]
      this.columnList = prop
    },
    // 只要点击搜索框,那么输入框里面的值inputContent就会传给searchContent,这是为了防止当输入框输入值后自动搜索
    searchinput () {
      this.searchContent = this.inputContent
      console.log(this.searchContent)
    }
  }
}
</script>

哪里出问题了,没实现效果

你定义了tables这个计算属性,但是从来没用到它,把模板里的表格区域换成用上它试试:

<el-table :data="tables" border stripe>
  <el-table-column type="index" label="#"></el-table-column>
  <el-table-column v-for="(item, index) in columnList" :key="index" :prop="item.prop" :label="item.label"></el-table-column>
</el-table>

把计算属性里换成这么写:

computed: {
    tables() {
      const search = this.searchContent.toLowerCase();
      if (this.inputContent === '') {
        // eslint-disable-next-line vue/no-side-effects-in-computed-properties
        this.searchContent = '';
        return this.allData;
      }
      return this.allData.filter((dataNews) => {
        return Object.values(dataNews).some((value) => {
          return String(value).toLowerCase().includes(search);
        });
      });
    }
  }

你之前的代码是拿data列表里每一个对象的每一个key(比如name)去和你输入框输入的值作比较,而且在不为空的情况下返回的是筛选过后的data列表和它的长度两者构成的数组,事实上你应该是拿data列表里每一个对象的每一个value(比如11)去和输入的值作比较,直接返回筛选出来的整个数组即可

我感觉你的Table组件用法是不是用复杂了。

<el-table-column />可以不用columnList去渲染

allData = [
    {
        name: '11',
        age: '11',
        city: '11'
    },
    {
        name: '12',
        age: '12',
        city: '12'
    },
    ...
]

使用:

<el-table :data="allData" border stripe>
    <el-table-column type="index" label="#"></el-table-column>

    <el-table-column prop="name" label="姓名"></el-table-column>
    <el-table-column prop="age" label="年龄"></el-table-column>
    <el-table-column prop="city" label="城市"></el-table-column>
</el-table>
收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

1. JK下载官网所有资源来源于开发团队,加入会员即可下载使用!如有问题请联系右下角在线客服!
2. JK下载官方保障所有软件都通过人工亲测,为每位会员用户提供安全可靠的应用软件、游戏资源下载及程序开发服务。
3. JK开发团队针对会员诉求,历经多年拥有现今开发成果, 每款应用程序上线前都经过人工测试无误后提供安装使用,只为会员提供安全原创的应用。
4. PC/移动端应用下载后如遇安装使用问题请联系右下角在线客服或提交工单,一对一指导解决疑难。

JK软件下载官网 技术分享 如何实现输入框和表格的联动,实现输入框输入内容查询表格数据? https://www.jkxiazai.com/2028.html

JK软件应用商店是经过官方安全认证,保障正版软件平台

相关资源

官方客服团队

为您解决烦忧 - 24小时在线 专业服务