vue实现条件叠加搜索的解决方法


Posted in Javascript onMay 28, 2019

案例场景:

现在有个文章管理模块,在该模块中有栏目选择、文章搜索、分页功能。这些功能改变其中一个都会对查询的文章有所改变。案例图如下:

vue实现条件叠加搜索的解决方法

实现方案有两种:

其一、我们开始可能会想到对每个功能绑定一个处理事件,但是这样做我们对数据的维护工作将大大加大,而且用这样方案做数据的叠加筛选不是很好。

方案二、我们将所有提交的数据放到一起维护然后再进行深度监听,当某一个值、或多个值的改变时,在去进行数据的查询,此时问题也变得更易于理解与维护,具体实现如下:

分页代码如下:

<template>
 <el-pagination
  background
  :page-size="params.pageSize"
  @current-change="handlePaginationChange"
  layout="prev, pager, next"
  :total="total">
 </el-pagination>
</template>

下拉选择框、搜索框代码如下: 

<template>
//下拉选择框
<el-select v-model="params.categoryId" placeholder="请选择栏目" size='mini'
 v-loading="loadingCategory">
 <el-option :key='c.id' v-for='c in categories' :label="c.name" :value="c.id"></el-option>
</el-select>
 
//搜索框
<el-input placeholder="请输入关键字"
 prefix-icon="el-icon-search"
 v-model="params.keywords"
  clearable>
</el-input>
</template>

数据维护、与方法(事件处理)

export default{
 data(){
  return{
   ... //其它的数据省略
 
   params:{ //存储分页、搜索数据
   page:0,
   pageSize:3,
   categoryId:undefined,
   keywords:undefined
   }
  }
 },
 watch:{
 params:{
  handler(val){
   this.findArticle(); //查找文章
  },
  deep:true //深度监听
 },
 methods:{
  //处理分页
  handlePaginationChange(page){
   this.params.page=page-1;
  }, 
  //查询文章
  findArticle(){
   axios.get('',{params:this.params})
   .then(()=>{})
   .catch(()=>{})
  }
 }
 
}

小结:通过上面的双向数据绑定、我们将所有数据放到 params中集中管理(进行数据的监听)、当数据发生改变时我们去请求数据,来局部更新表格中的数据。

存在问题与解决:

1.这种实现方法的实现是基于所有数据的和查询、如果我们的需求是,当每次选择栏目时,都要显示第一页栏目的文章;

解决方案:

一、此时我们可以给选择的栏目加change事件、然后将page重置为第一页(本项目是从第0页开始),具体代码如下:

1.1 将分页中动态绑定page  即:  :current-page="(params.page+1)"

<template>
 <el-pagination
  background
  :page-size="params.pageSize"
  :total="total"
  layout="prev, pager, next"
  :current-page="(params.page+1)" //将页数进行动态绑定这样利于我们操作页数的改变
  @current-change="handlePaginationChange"
  >
 </el-pagination>
 
</template>

1.2  给select添加change事件

<template> 
 //下拉选择框
 <el-select v-model="params.categoryId" placeholder="请选择栏目" size='mini'
   @change="selectChange"
  >
  <el-option :key='c.id' v-for='c in categories' :label="c.name" :value="c.id">
  </el-option>
 </el-select>
</template>
 
export default{
 //重置page为0
 selectChange(){
  this.params.page=0;
 },
}

***:此时我们存在的问题是如果我们先点击某一页后然后再点击栏目,那么会基于本页去查询选择栏目的信息。

二、关于搜索时我的理想是对当前页信息进行筛选、如果有人想要做出对所有数据的筛选、那么此时我们应该将keywords单独拿出来进行,搜索这样解决起来比加条件简单许多。

只是我目前对多个信息筛选做出的一个解决方案、如果有更加友好的处理方法、希望能留言。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
由prototype_1.3.1进入javascript殿堂-类的初探
Nov 06 Javascript
疯狂Jquery第一天(Jquery学习笔记)
May 11 Javascript
javascript继承之为什么要继承
Nov 10 Javascript
js获取指定的cookie的具体实现
Feb 20 Javascript
Javascript 赋值机制详解
Nov 23 Javascript
jQuery插件FusionCharts实现的MSBar2D图效果示例【附demo源码】
Mar 24 jQuery
jQuery实现简单的滑动导航代码(移动端)
May 22 jQuery
jQuery简介_动力节点Java学院整理
Jul 04 jQuery
Javascript的this详解
Mar 23 Javascript
Vue通过WebSocket建立长连接的实现代码
Nov 05 Javascript
jQuery开发仿QQ版音乐播放器
Jul 10 jQuery
vue 验证两次输入的密码是否一致的方法示例
Sep 29 Javascript
webpack4 从零学习常用配置(小结)
May 28 #Javascript
详解ES6 export default 和 import语句中的解构赋值
May 28 #Javascript
jQuery实现高级检索功能
May 28 #jQuery
利用原生JS实现data方法示例代码
May 28 #Javascript
php结合js实现多条件组合查询
May 28 #Javascript
vue实现前台列表数据过滤搜索、分页效果
May 28 #Javascript
js 将线性数据转为树形的示例代码
May 28 #Javascript
You might like
php新建文件自动编号的思路与实现
2011/06/27 PHP
浅析php中三个等号(===)和两个等号(==)的区别
2013/08/06 PHP
PHP中检索字符串的方法分析【strstr与substr_count方法】
2017/02/17 PHP
Laravel使用支付宝进行支付的示例代码
2017/08/16 PHP
javascript 可以拖动的DIV(二)
2009/06/26 Javascript
将查询条件的input、select清空
2014/01/14 Javascript
使用原生js写的一个简单slider
2014/04/29 Javascript
浅谈jQuery事件绑定原理
2015/01/02 Javascript
JavaScript获取表单enctype属性的方法
2015/04/02 Javascript
jquery实现简单的banner轮播效果【实例】
2016/03/30 Javascript
jQuery循环遍历子节点并获取值的方法
2016/04/14 Javascript
利用BootStrap弹出二级对话框的简单实现方法
2016/09/21 Javascript
js 定位到某个锚点的方法
2016/11/19 Javascript
jQuery实现百度登录框的动态切换效果
2017/04/21 jQuery
js 事件的传播机制(实例讲解)
2017/07/20 Javascript
JS实现可视化文件上传
2018/09/08 Javascript
Easyui 去除jquery-easui tab页div自带滚动条的方法
2019/05/10 jQuery
jQuery 添加元素和删除元素的方法
2020/07/15 jQuery
Python socket.error: [Errno 98] Address already in use的原因和解决方法
2014/08/25 Python
Python常用模块介绍
2014/11/21 Python
python根据时间生成mongodb的ObjectId的方法
2015/03/13 Python
用Python实现通过哈希算法检测图片重复的教程
2015/04/02 Python
基于python进行桶排序与基数排序的总结
2018/05/29 Python
Python实现绘制双柱状图并显示数值功能示例
2018/06/23 Python
Python3自定义http/https请求拦截mitmproxy脚本实例
2020/05/11 Python
Python虚拟环境venv用法详解
2020/05/25 Python
小学体育教学反思
2014/01/31 职场文书
国际贸易系求职信
2014/08/09 职场文书
消防志愿者活动方案
2014/08/23 职场文书
领导班子四风表现材料
2014/08/23 职场文书
乡镇创先争优活动总结
2014/08/28 职场文书
2014年学校体育工作总结
2014/12/08 职场文书
交通事故和解协议书
2015/01/27 职场文书
嘉年华活动新闻稿
2015/07/17 职场文书
判断Python中的Nonetype类型
2021/05/25 Python
python用tkinter开发的扫雷游戏
2021/06/01 Python