uni-app搜索历史记录功能实现

今天也是在提测的时候遇到了一些问题,用的是随商的商城系统。

H5 商品和店铺搜索的时候,有一个搜索历史记录功能。但是测试时发现历史记录中的关键词,再次搜索时不能跳转。

检查了一下代码,在触发搜索的时候,会去一下缓存中的数组,如果搜索关键词在数组中有的就直接 return 了。

于是我就改造,重写了一下:

  1. searchStart: function () {
  2.   let _this = this;
  3.   if (_this.searchText == '') {//搜索关键词为空
  4.     uni.showToast({//提示信息
  5.       title: '请输入关键字',
  6.       icon: 'none',
  7.       duration: 1000
  8.     });
  9.   } else {
  10.     uni.getStorage({//从缓存中取搜索历史记录的数组
  11.       key: 'search_cache',
  12.       success(res) {//获取成功
  13.         let list = res.data;
  14.         for (let i in list) {//循环遍历
  15.           if (list[i] == _this.searchText) {//如果缓存数组中有搜索关键词
  16.             list.splice(i, 1)//删除数组中的该关键词
  17.           }
  18.         }
  19.         list.unshift(_this.searchText);//将搜索关键词添加到数组开头
  20.         list.splice(6)//只保留6个
  21.         _this.hList = list;
  22.         uni.setStorage({//将新的数组存入缓存
  23.           key: 'search_cache',
  24.           data: _this.hList,
  25.         });
  26.         _this.search(_this.searchText);//搜索
  27.       },
  28.       fail() {//没有获取到缓存
  29.         _this.hList = [];
  30.         _this.hList.push(_this.searchText);
  31.         uni.setStorage({
  32.           key: 'search_cache',
  33.           data: _this.hList,
  34.         });
  35.         _this.search(_this.searchText);//搜索
  36.       }
  37.     })
  38.   }
  39. }

这样可以在搜索的时候查一下缓存,如果有重复,就删除原数组中的该关键词,然后添加到数组的开头。

然后删除数组第6个以后的元素(保留6条搜索历史),存入缓存,跳转搜索。

这样就可以实现搜索历史记录功能了,如果有更好的方法或者建议,可以在下方评论区指出。

未经允许不得转载:前端资源网 - w3h5 » uni-app搜索历史记录功能实现

赞 (1)
分享到: +

评论 沙发

Avatar

换个身份

  • 昵称 (必填)
  • 邮箱 (选填)