【小程序项目开发-- 京东商城】uni-app之自定义搜索组件(中)-- 搜索建议

简介: 【小程序项目开发-- 京东商城】uni-app之自定义搜索组件(中)-- 搜索建议

文章目录

一、 渲染UI结构

  • 可在开发工具中添加该页面编译模式(每次编译即在该页面)

使用uni-app官方搜索组件可快速搭建 输入框

图片.png

通过官方组件提供的搜索组件以及自定义结构如下

<uni-search-bar :radius="100" @input="input" cancelButton="none" bgColor="#dfdfdf"></uni-search-bar>

效果:

图片.png

  • 设置背景方法一(用view包裹,设置样式):
<view class="search-box">
   <uni-search-bar :radius="100" @input="input" cancelButton="none" bgColor="#dfdfdf"></uni-search-bar>
   </view>
 .search-box {
   background-color: #ff1e0a;
 }
  • 设置背景方法二(在官方组件内设置)
    uni_modules找到官方组件包

图片.png图片.png

  • 效果(一样)

图片.png

  • 添加吸顶效果(保持在页面顶部)
 .search-box {
   // 吸顶
   position: sticky;
   top: 0;
   z-index: 999;
 }

二、 input事件处理

在input组件中,输入的值都在input对该函数所传的参数中(不是e.value,官方将input事件绑定事件结构为value值)

 methods: {
      // 搜索框input事件处理
      input(e){
        console.log(e)  // 输出对应值
      } 
    }

效果

26.gif

三、搜索框自动获取焦点

实现在用户点击搜索框 跳转到搜索页面时,搜索框自动获取焦点(可输入)

  • 在官方组件源文件修改如下show , showsync属性为true(使其判断为真,焦点为真显示)图片.png
  • 修改如下图片.png
  • 注意(预览效果需要在真机上预览,开发工具上与真机或多或少有些不兼容):27.gif

四、防抖处理

可以看到,每次输入键入一次数据都会触发一次input请求,我们设置在五百毫秒内用户输入数据时不触发请求,五百毫秒后用户没有输入数据时触发请求,实现 防抖处理

28.gif

这里我们通过JavaScript 延时器中的setTimeoutclearTimeout实现(延时与取消延时

  • setTimeout语法格式
setTimeout(要执行的代码, 等待的毫秒数)
setTimeout(JavaScript 函数, 等待的毫秒数)
  • clearTimeout语法格式
clearTimeout() 方法可取消由 setTimeout() 方法设置的定时操作。
clearTimeout() 方法的参数必须是由 setTimeout() 返回的 ID 值(对应取消)。
  • 最终实现代码(注意 timer 是全局变量
 data() {
      return {
        inputString: '',
        timer: null
      };
    },
    methods: {
      // 搜索框input事件处理
      input(e) {
        // 触发事件 取消赋值操作
        clearTimeout(timer)
        // 500毫秒后赋值
        timer = setTimeout(() => {
          this.inputString = e
          console.log(this.inputString)
        }, 500)
      }

效果:

29.gif

五、根据关键词查询搜索建议列表

5.1 数据请求

  • 请求参数
参数名 参数说明 备注
query 查询内容 如: goods/qsearch?query=小米
  • 接口数据样式
{
    "message": [
        {
            "goods_id": 57332,
            "goods_name": "400毫升 海鲜食品冷藏冰包 注水冰袋医用冰袋户外冷藏保鲜熟食冷藏反复使用(10个装)"
        },
        {
            "goods_id": 57194,
            "goods_name": "亿力洗车工具汽车美容用品海绵刷不伤车漆擦车海棉清洁海绵"
        }
    ],
    "meta": {
        "msg": "获取成功",
        "status": 200
    }
}
  • 定义data数据节点searchResults
    data() {
      return {
        inputString: '',
        timer: null,
        searchResults: ''
      };
    },
  • 再input事件处理函数中调用 获取数据函数getsearchList
 input(e) {
        // 触发事件 取消赋值操作
        clearTimeout(this.timer)
        // 500毫秒后赋值
        this.timer = setTimeout(() => {
          this.inputString = e
          this.getSearchList()
        }, 500)
      }
  • 定义getsearchList函数(判断是否为空格和空字符串
 async getSearchList() {
        // 如果是空字符串则 不请求
        if (this.inputString == '') {
          this.searchSuggest = []
          return
        }
        // 如果为空格,则报错
        else if (this.inputString.trim() === '') return uni.$showMsg('输入内容有误')
        const {
          data: res
        } = await uni.$http.get('/api/public/v1/goods/qsearch', {
          query: this.inputString
        })
        // 请求错误报错
        if (res.meta.status != 200) return uni.$showMsg()
        // 赋值
        this.searchSuggest = res.message
      },
  • 效果(可以看到searchList成功接受到了值):30.gif
  • 输入空格报错31.gif

5.2 渲染UI结构

  • 结构
 <!-- 搜索建议列表容器 -->
    <view class="sgg-list-container">
    <view class="sgg-item" v-for="(product,i) in searchResults" v-bind:key="i">
      <view class="sgg-name">{{product.goods_name}}</view>
      <uni-icons type="right"></uni-icons>
    </view>
  </view>
  • 样式
.sgg-list-container {
 .sgg-item {
   display: flex;
   background-color: #fff;
   align-items: center;
   border-top: 3rpx solid #efefef;
   justify-content: space-between;
   padding: 20rpx 10rpx;
   .sgg-name {
     // 不允许换行
     white-space: nowrap;
     // 超出不显示
     overflow: hidden;
     // 超出文本用ellipsis代替
     text-overflow: ellipsis;
     margin-right: 5rpx;
     font-size: 28rpx;
   }
 }
}

效果:

33.gif

5.3 点击建议跳转详情页

  • 方法一 组件式跳转: 将view 改为 navigator组件 并传商品ID参数

结构

 <!-- 搜索建议列表容器 -->
    <view class="sgg-list-container">
    <navigator class="sgg-item" v-for="(product,i) in searchResults" v-bind:key="i" :url="'/subpackages/goods_list/goods_list?cat_id=' + product.goods_id">
      <view class="sgg-name">{{product.goods_name}}</view>
      <uni-icons type="right"></uni-icons>
    </navigator>
  </view>
  • 方法二 编程式跳转: 绑定click 事件,定义函数
 <!-- 搜索建议列表容器 -->
    <view class="sgg-list-container">
    <view class="sgg-item" v-for="(product,i) in searchResults" v-bind:key="i" @click="gotogoodlist(product)">
      <view class="sgg-name">{{product.goods_name}}</view>
      <uni-icons type="right"></uni-icons>
    </view>
  </view>
gotogoodlist(item){
  uni.navigatorto({
     url = "'/subpackages/goods_list/goods_list?cat_id=' + item.goods_id"
})

效果:

34.gif

✨谢谢你的阅读,您的点赞和收藏就是我创造的最大动力!✨



相关文章
|
2月前
|
JSON 小程序 JavaScript
uni-app开发微信小程序的报错[渲染层错误]排查及解决
uni-app开发微信小程序的报错[渲染层错误]排查及解决
660 7
|
2月前
|
小程序 JavaScript 前端开发
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
uni-app开发微信小程序:四大解决方案,轻松应对主包与vendor.js过大打包难题
732 1
|
5天前
|
移动开发 小程序 PHP
校园圈子论坛系统采取的PHP语音和uni账号开发的小程序APP公众号H5是否只需要4800元?是的,就是只需要4800元
关于校园圈子论坛系统采用PHP语言和uni-app开发的小程序、APP、公众号和H5是否仅需4800元这个问题,实际上很难给出一个确定的答案。这个价格可能受到多种因素的影响
|
1天前
|
人工智能 小程序 数据处理
uni-app开发AI康复锻炼小程序,帮助肢体受伤患者康复!
近期,多家康复机构咨询AI运动识别插件是否适用于肢力运动受限患者的康复锻炼。本文介绍该插件在康复锻炼中的应用场景,包括康复运动指导、运动记录、恢复程度记录及过程监测。插件集成了人体检测、姿态识别等功能,支持微信小程序平台,使用便捷,安全可靠,帮助康复治疗更加高效精准。
|
8天前
|
缓存 移动开发 小程序
uni-vue3-wetrip自创跨三端(H5+小程序+App)酒店预订app系统模板
vue3-uni-wetrip原创基于vite5+vue3+uniapp+pinia2+uni-ui等技术开发的仿去哪儿/携程预约酒店客房app系统。实现首页酒店展示、预订搜索、列表/详情、订单、聊天消息、我的等模块。支持编译H5+小程序+App端。
44 8
|
23天前
|
移动开发 小程序
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
仿青藤之恋社交交友软件系统源码 即时通讯 聊天 微信小程序 App H5三端通用
49 3
|
28天前
|
小程序 前端开发 JavaScript
在线课堂+工具组件小程序uniapp移动端源码
在线课堂+工具组件小程序uniapp移动端源码
29 0
在线课堂+工具组件小程序uniapp移动端源码
|
1月前
|
小程序 机器人 开发者
QQ 小程序已发布,但无法被搜索的解决方案
我的 QQ 小程序在 2024 年 8 月就已经审核通过,上架后却一直无法被搜索到。打开后,再在 QQ 上下拉查看 “最近使用”,发现他出现一下又马上消失。
41 2
家政服务小程序APP开发,做好上门家政最快的方法是什么?
在家政服务领域,打造成功的平台并非易事。本文分享了三个关键步骤:避免初期盲目投入、采用低成本获客方式、建立有效的阿姨筛选机制。遵循这些方法,可助你避开常见陷阱,成为行业头部平台。
|
1月前
|
小程序 数据挖掘 UED
开发1个上门家政小程序APP系统,都有哪些功能?
在快节奏的现代生活中,家政服务已成为许多家庭的必需品。针对传统家政服务存在的问题,如服务质量不稳定、价格不透明等,我们历时两年开发了一套全新的上门家政系统。该系统通过完善信用体系、提供奖励机制、优化复购体验、多渠道推广和多样化盈利模式,解决了私单、复购、推广和盈利四大痛点,全面提升了服务质量和用户体验,旨在成为家政行业的领导者。