首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >【小程序项目开发-- 京东商城】uni-app之自定义搜索组件(中)-- 搜索建议

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

作者头像
计算机魔术师
发布于 2022-08-23 01:45:58
发布于 2022-08-23 01:45:58
1.1K0
举报
文章被收录于专栏:计算机魔术师计算机魔术师

👋👋欢迎来到👋👋 🎩魔术之家!!🎩 该文章收录专栏 ✨ 2022微信小程序京东商城实战 ✨ 专栏内容 ✨ 京东商城uni-app项目搭建 ✨ ✨ 京东商城uni-app 配置tabBar & 窗口样式 ✨ ✨ 京东商城uni-app开发之分包配置 ✨ ✨ 京东商城uni-app开发之轮播图 ✨ ✨ 京东商城uni-app之分类导航区域 ✨ ✨ 京东商城uni-app 首页楼层商品 ✨ ✨ 京东商城uni-app 商品分类页面(上) ✨ ✨ 京东商城uni-app 商品分类页面(下) ✨ ✨ 京东商城uni-app之自定义搜索组件(上) ✨ ✨ 京东商城uni-app之自定义搜索组件(中) ✨

文章目录

一、 渲染UI结构

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

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

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

代码语言:javascript
AI代码解释
复制
<uni-search-bar :radius="100" @input="input" cancelButton="none" bgColor="#dfdfdf"></uni-search-bar>

效果:

  • 设置背景方法一(用view包裹,设置样式):
代码语言:javascript
AI代码解释
复制
<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找到官方组件包

  • 效果(一样)
  • 添加吸顶效果(保持在页面顶部)
代码语言:javascript
AI代码解释
复制
 .search-box {
   // 吸顶
   position: sticky;
   top: 0;
   z-index: 999;
 }

二、 input事件处理

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

代码语言:javascript
AI代码解释
复制
 methods: {
      // 搜索框input事件处理
      input(e){
        console.log(e)  // 输出对应值
      } 
    }

效果

三、搜索框自动获取焦点

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

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

四、防抖处理

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

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

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

效果:

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

5.1 数据请求

  • 请求参数

参数名

参数说明

备注

query

查询内容

如: goods/qsearch?query=小米

  • 接口数据样式
代码语言:javascript
AI代码解释
复制
{
    "message": [
        {
            "goods_id": 57332,
            "goods_name": "400毫升 海鲜食品冷藏冰包 注水冰袋医用冰袋户外冷藏保鲜熟食冷藏反复使用(10个装)"
        },
        {
            "goods_id": 57194,
            "goods_name": "亿力洗车工具汽车美容用品海绵刷不伤车漆擦车海棉清洁海绵"
        }
    ],
    "meta": {
        "msg": "获取成功",
        "status": 200
    }
}
  • 定义data数据节点searchResults
代码语言:javascript
AI代码解释
复制
    data() {
      return {
        inputString: '',
        timer: null,
        searchResults: ''
      };
    },
  • 再input事件处理函数中调用 获取数据函数getsearchList
代码语言:javascript
AI代码解释
复制
 input(e) {
        // 触发事件 取消赋值操作
        clearTimeout(this.timer)
        // 500毫秒后赋值
        this.timer = setTimeout(() => {
          this.inputString = e
          this.getSearchList()
        }, 500)
      }
  • 定义getsearchList函数(判断是否为空格和空字符串
代码语言:javascript
AI代码解释
复制
 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成功接受到了值):
  • 输入空格报错

5.2 渲染UI结构

  • 结构
代码语言:javascript
AI代码解释
复制
 <!-- 搜索建议列表容器 -->
    <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>
  • 样式
代码语言:javascript
AI代码解释
复制
.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;
   }
 }
}

效果:

5.3 点击建议跳转详情页

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

结构

代码语言:javascript
AI代码解释
复制
 <!-- 搜索建议列表容器 -->
    <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 事件,定义函数
代码语言:javascript
AI代码解释
复制
 <!-- 搜索建议列表容器 -->
    <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"
})

效果:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022/07/09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
python实现自动向钉钉群推送消息
步骤一:【电脑钉钉 】-【群聊】-【群设置】-【智能群助手】-【添加更多】-【添加机器人】-【自定义】-【添加】,编辑机器人名称和选择添加的群组。
墨紫羽墨
2021/12/12
1.8K0
路由器日志通过钉钉机器人自动推送
由于申请的电信宽带IP不是固定的,每次变了IP又不知道,需要有个IP变更提醒的小功能。
萌海无涯
2020/05/09
1.3K0
PYTHON 连接钉钉传输工作数据监控
“我报名参加金石计划1期挑战——瓜分10万奖池,这是我的第1篇文章,点击查看活动详情”
百里丶落云
2022/11/03
8380
PYTHON 连接钉钉传输工作数据监控
Python - 接入钉钉机器人
https://developers.dingtalk.com/document/robots/use-group-robots
小菠萝测试笔记
2021/11/18
1.1K0
Python - 接入钉钉机器人
python钉钉机器人自定义回复
然后去实现handle_client 就好了。篇幅有限。完整的代码关注公众号 罗尔街 即可获取
Michel_Rolle
2023/07/30
4.2K4
如何用Python发送告警通知到钉钉?
前不久,看到了明哥写的如何用Python发送警告通知到企业微信,想起来之前写过用Pytho发送指定格式数据到钉钉的服务,本文将之前的代码重构下,变成一个:利用Python监控服务器数据,然后有异常就通过钉钉发送给用户。
老表
2021/12/27
2.5K0
如何用Python发送告警通知到钉钉?
Python - 抓取 iphone13 pro 线下店供货信息并发送到钉钉机器人,最后设置为定时任务
盲猜是这个 storeSelectionEnabled 字段影响的,因为只有它是 False,当然也有猜过是下面的 pickupDisplay,但从命名来看,第一个才是影响是否可选中的字段
小菠萝测试笔记
2021/11/18
1K0
Python - 抓取 iphone13 pro 线下店供货信息并发送到钉钉机器人,最后设置为定时任务
开通与使用钉钉群机器人 [附API代码]
目录 开通方式 参考代码 使用示范 开通方式 免费,有群就能开,任何用户都可开 官方文档:自定义机器人接入 - 钉钉开放平台 注意事项:用电脑版钉钉来开通,手机上的不行。 参考代码 import time import hmac import hashlib import base64 import urllib.parse import io from pyzbar import pyzbar from PIL import Image import requests, json # 导入依赖
小锋学长生活大爆炸
2022/03/29
1.8K0
开通与使用钉钉群机器人 [附API代码]
python自动化高效办公第二期,带你项目实战【二】{数据可视化、发送邮件(定时任务监控)、python聊天机器人(基于微信、钉钉)}
API商城_API_API接口大全_API一站式采购基地百度智能云API商城-API一站式采购基地,API商城提供天气查询API、实名认证API、短信验证码、OCR识别等海量API服务。选购API服务,首选百度智能云API商城。
汀丶人工智能
2022/12/21
1.3K0
python自动化高效办公第二期,带你项目实战【二】{数据可视化、发送邮件(定时任务监控)、python聊天机器人(基于微信、钉钉)}
我是怎样用Shell脚本完成钉钉机器人消息推送的
我喜欢shell,是因为在Linux环境下,几乎可以完成所有的事儿,而且依赖问题几乎可以忽略不计(一些特殊环境除外)。 所从这个角度出发,我大部分的代码都会优选Shell,当shell无法完成时我才会借助第三方语言来辅助,比如:PHP、Python等
爱技术的小黄鸭
2023/06/15
2.2K2
我是怎样用Shell脚本完成钉钉机器人消息推送的
自动化系列(四)Python实现钉钉机器人
定期数据需求除了以邮件的形式交付外,也可以发送到工作群里通知相关人员及时关注,本文将介绍如何推送数据到钉钉群里并@相关人员及时关注。
HsuHeinrich
2023/02/24
1.6K0
自动化系列(四)Python实现钉钉机器人
从 0 到 1 使用 Python 开发一个钉钉群应答机器人[附完整源码]
很多时候,我们都希望计算机程序能够为我们自动化的处理一些学习、工作和生活上的任务,毕竟「偷懒」可是促进科技进步和社会发展的一大动力。基于这种需求,诞生了很多种自动化的工具,比如爬虫,自动地帮我们采集数据;比如智能问答机器人,自动地回答客户提出的问题。
州的先生
2021/06/21
5.7K0
从 0 到 1 使用 Python 开发一个钉钉群应答机器人[附完整源码]
使用python3.7配置开发钉钉群自定义机器人(2020年新版攻略)
    最近疫情比较严重,很多公司依靠阿里旗下的办公软件钉钉来进行远程办公,当然了,钉钉这个产品真的是让人一言难尽,要多难用有多难用,真的让人觉得阿里的pm都是脑残才会设计出这种脑残产品,不过吐槽归吐槽,该用还得用,虽然钉钉别的功能很鸡肋,但是机器人这个功能还是让人眼前一亮,属于比较极客的功能,它可以将第三方服务的信息聚合到钉钉群中,实现信息的自动化同步,例如:通过聚合Github、Gitlab等源码管理服务,实现源码更新同步;通过聚合Trello、JIRA等项目协调服务,实现项目信息同步;同事,支持Webhook协议的自定义接入,支持更多可能性,例如:将运维报警提醒、自动化测试的结果报告提醒、工作、生活日程安排(上班打卡、下班吃饭、健身、读书、生日、纪念日...)等等的提醒,通过自定义机器人聚合到钉钉中。
用户9127725
2022/08/08
1K0
使用python3.7配置开发钉钉群自定义机器人(2020年新版攻略)
把盏言欢,款款而谈,ChatGPT结合钉钉机器人(outgoing回调)打造人工智能群聊/单聊场景,基于Python3.10
    就像黑火药时代里突然诞生的核弹一样,OpenAI的ChatGPT语言模型的横空出世,是人工智能技术发展史上的一个重要里程碑。这是一款无与伦比、超凡绝伦的模型,能够进行自然语言推理和对话,并且具有出色的语言生成能力。
用户9127725
2022/12/09
2.1K0
把盏言欢,款款而谈,ChatGPT结合钉钉机器人(outgoing回调)打造人工智能群聊/单聊场景,基于Python3.10
Prometheus告警集成到钉钉
集成到钉钉 编写python flask脚本 cat > app.py <<EOF #!/usr/bin/python # -*- coding: utf8 -*- from flask import Flask from flask import request import time import hmac import hashlib import base64 import urllib import requests import json import sys reload(sys)
mikelLam
2022/10/31
6490
Python 运用Paramiko实现批量巡检
通过封装Paramiko这个SSH模块,我们可以实现远程批量管理Linux主机,在此基础上配合钉钉API接口可实现自动告警机制,定期自动检查设备状态,并推送到钉钉群内。
王瑞MVP
2022/12/28
1.3K0
Python 运用Paramiko实现批量巡检
Shell实现钉钉机器人定时消息通知
我们知道,之前的运维告警多通过SMS、Mail 等方式通知到相应的人员,难以实现随时随地的查看。随着手机APP的发展,很多告警开始发送到IM软件上去。目前比较常用的是发送到微信和钉钉上,不过微信发送时,需要开通企业公众号,比较麻烦。今天我们将重点放在钉钉上。群机器人是钉钉群的高级扩展功能,群机器人可以将第三方服务的信息聚合到群聊中,实现自动化的信息同步。借助钉钉机器人,通过官方提供的API,可以很方便的post数据到相应的接收人 。群机器人支持Webhook协议的自定义接入,支持更多可能性,例如:你可将运维报警通过自定义机器人聚合到钉钉群实现提醒功能。
非著名运维
2022/06/22
1.6K0
Shell实现钉钉机器人定时消息通知
红队作业 | 钉钉机器人远控服务器体验
钉钉,阿里巴巴出品,专为全球企业组织打造的智能移动办公平台,含PC版,IPad和手机版。远程视频会议,消息已读未读,DING消息任务管理,让沟通更高效;移动办公考勤,签到,审批,钉闪会,钉钉文档,钉钉教育解决方案,让工作学习更简单!
Ms08067安全实验室
2022/04/06
1.9K0
红队作业 | 钉钉机器人远控服务器体验
Android Studio 中编辑Groovy 脚本 给钉钉机器人发消息
最近有一些需求,需要学习和配置Groovy脚本。而电脑上安装的编译器Android Studio。
zinyan.com
2022/12/07
1.2K0
java 钉钉 "errcode":310000,"errmsg":"sign not match
事情是这样的,老大不知道从什么地方找了一个钉钉发送消息的代码,什么说明都没有,让把代码调试通!
赵哥窟
2021/06/11
4K0
java 钉钉 "errcode":310000,"errmsg":"sign not match
推荐阅读
相关推荐
python实现自动向钉钉群推送消息
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
首页
学习
活动
专区
圈层
工具
MCP广场
首页
学习
活动
专区
圈层
工具
MCP广场