uniapp-搜索配置

news2024/11/16 1:32:11

自定义搜索组件

1.定义组件的 UI 结构:

<template>
  <!-- 通过属性绑定的形式,为 .my-search-container 盒子和 .my-search-box 盒子动态绑定 style 属性 -->
  <view class="my-search-container" :style="{'background-color': bgcolor}">
    <!-- 使用 view 组件模拟 input 输入框的样式 -->
    <!-- 在 my-search 自定义组件内部,给类名为 .my-search-box 的 view 绑定 click 事件处理函数 -->
    <view class="my-search-box" :style="{'border-radius': radius + 'px'}" @click="searchBoxHandler">
      <uni-icons type="search" size="17"></uni-icons>
      <text class="placeholder">搜索</text>
    </view>
  </view>
</template>

2.自定义属性与事件:

<script>
	export default {
		name:"my-search",
		data() {
			return {				
			};
		},
		methods: {
		  // 点击了模拟的 input 输入框
		  searchBoxHandler() {
		    // 触发外界通过 @click 绑定的 click 事件处理函数
		    this.$emit('click')
		  }
		},
		props: {
		  // UI结构中的背景颜色
		  bgcolor: {
		    type: String,
		    default: '#C00000'
		  },
		  //  UI结构中的圆角尺寸
		  radius: {
		    type: Number,
		    // 单位是 px
		    default: 18
		  }
		}
	}
</script>

3.美化组件的样式:

<style lang="scss">
.my-search-container {
  // 移除背景颜色,改由 props 属性控制
  // background-color: #c00000;
  height: 50px;
  padding: 0 10px;
  display: flex;
  align-items: center;
}

.my-search-box {
  height: 36px;
  background-color: #ffffff;
  // 移除圆角尺寸,改由 props 属性控制
  // border-radius: 15px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;

  .placeholder {
    font-size: 15px;
    margin-left: 5px;
  }
}
</style>

4.其他页面的调用:

<template>
	<!-- 使用自定义的搜索组件 -->
	<my-search @click="gotoSearch"></my-search>
</template>

<script>
	export default{
	    //定义 gotoSearch 事件处理函数
		methods: {
		   // 跳转到分包中的搜索页面
		   gotoSearch() {
		     uni.navigateTo({
		       url: '/subpkg/search/search'
		     })
		   }
		}
	}
</script>

<!-- 吸顶效果的实现 -->
<style lang="scss">
	.search-box {
	  // 设置定位效果为“吸顶”
	  position: sticky;
	  // 吸顶的“位置”
	  top: 0;
	  // 提高层级,防止被轮播图覆盖
	  z-index: 999;
	}
</style>

效果:

在这里插入图片描述

搜索页面

1.定义页面的UI结构:

<template>
	<view>
	  <view class="search-box">
	    <!-- 使用 uni-ui 提供的搜索组件 -->
	    <uni-search-bar @input="input" :radius="100" cancelButton="none"  placeholder="请输入搜索内容"></uni-search-bar>
	  </view>
	  
	  <!-- 搜索建议列表 搜索长度不为0时显示-->
	  <view class="sugg-list" v-if="searchResults.length !== 0">
	    <view class="sugg-item" v-for="(item, i) in searchResults" :key="i" @click="gotoDetail(item.goods_id)">
	      <view class="goods-name">{{item.goods_name}}</view>
	      <uni-icons type="arrowright" size="16"></uni-icons>
	    </view>
	  </view>
	  
	  <!-- 搜索历史 搜索长度为0时显示-->
	  <view class="history-box" v-else>
	    <!-- 标题区域 -->
	    <view class="history-title">
	      <text>搜索历史</text>
	      <uni-icons type="trash" size="17" @click="cleanHistory"></uni-icons>
	    </view>
	    <!-- 列表区域 -->
	    <view class="history-list">
	      <uni-tag :text="item" v-for="(item, i) in historys" :key="i" @click="gotoGoodsList(item)"></uni-tag>
	    </view>
	  </view>
	</view>
</template>

2.自定义脚本:

<script>
	export default {
		data() {
			return {
			  // 延时器的 timerId
			  timer: null,
			  // 搜索关键词
			  kw: '',
			  // 搜索结果列表
			  searchResults: [],
		      // 搜索关键词的历史记录(假数据)
		      historyList: ['a', 'app', 'apple']
			};
		},
		methods: {
		  //input 事件处理函数
		  input(e) {
		    // 清除 timer 对应的延时器
		    clearTimeout(this.timer)
		    // 重新启动一个延时器,并把 timerId 赋值给 this.timer
		    this.timer = setTimeout(() => {
		      // 如果 500 毫秒内,没有触发新的输入事件,则为搜索关键词赋值
		      this.kw = e
			  this.getSearchList()
		      console.log(this.kw)
		    }, 500)
		  },
		  
		  async getSearchList() {
		    // 判断关键词是否为空
		    if (this.kw === '') {
		      this.searchResults = []
		      return
		    }
		    // 发起请求,获取搜索建议列表
		    const { data: res } = await uni.$http.get('/api/public/v1/goods/qsearch', { query: this.kw })
		    if (res.meta.status !== 200) return uni.$showMsg()
		    this.searchResults = res.message
			// 1. 查询到搜索建议之后,调用 saveSearchHistory() 方法保存搜索关键词
			this.saveSearchHistory()
		  },
		  
		  gotoDetail(goods_id) {
		    uni.navigateTo({
		      // 指定详情页面的 URL 地址,并传递 goods_id 参数
		      url: '/subpkg/goods_detail/goods_detail?goods_id=' + goods_id
		    })
		  },
		  
		  // 2. 保存搜索关键词的方法
		  // 保存搜索关键词为历史记录
		  saveSearchHistory() {
		    // this.historyList.push(this.kw)
		  
		    // 1. 将 Array 数组转化为 Set 对象(利用set去重)
		    const set = new Set(this.historyList)
		    // 2. 调用 Set 对象的 delete 方法,移除对应的元素
		    set.delete(this.kw)
		    // 3. 调用 Set 对象的 add 方法,向 Set 中添加元素
		    set.add(this.kw)
		    // 4. 将 Set 对象转化为 Array 数组
		    this.historyList = Array.from(set)
			// 调用 uni.setStorageSync(key, value) 将搜索历史记录持久化存储到本地
			uni.setStorageSync('kw', JSON.stringify(this.historyList))
		  },
		  
		  // 清空搜索历史记录
		  cleanHistory() {
		    // 清空 data 中保存的搜索历史
		    this.historyList = []
		    // 清空本地存储中记录的搜索历史
		    uni.setStorageSync('kw', '[]')
		  },
		  
		  // 点击跳转到商品列表页面
		  gotoGoodsList(kw) {
		    uni.navigateTo({
		      // 指定详情页面的 URL 地址,并传递 goods_id 参数
		      url: '/subpkg/goods_list/goods_list?query=' + kw
		    })
		  }
		},
		computed: {
		  historys() {
		    // 注意:由于数组是引用类型,所以不要直接基于原数组调用 reverse 方法,以免修改原数组中元素的顺序
		    // 而是应该新建一个内存无关的数组,再进行 reverse 反转
		    return [...this.historyList].reverse()
		  }
		},
		//加载本地存储的搜索历史记录
		onLoad() {
		  this.historyList = JSON.parse(uni.getStorageSync('kw') || '[]')
		}
	}
</script>

3.美化样式:

<style lang="scss">
.search-box {
  // 设置定位效果为“吸顶”
  position: sticky;
  // 吸顶的“位置”
  top: 0;
  // 提高层级,防止被轮播图覆盖
  z-index: 999;
}

.sugg-list {
  padding: 0 5px;

  .sugg-item {
    font-size: 12px;
    padding: 13px 0;
    border-bottom: 1px solid #efefef;
    display: flex;
    align-items: center;
    justify-content: space-between;

    .goods-name {
      // 文字不允许换行(单行文本)
      white-space: nowrap;
      // 溢出部分隐藏
      overflow: hidden;
      // 文本溢出后,使用 ... 代替
      text-overflow: ellipsis;
      margin-right: 3px;
    }
  }
}

.history-box {
  padding: 0 5px;

  .history-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 40px;
    font-size: 13px;
    border-bottom: 1px solid #efefef;
  }

  .history-list {
    display: flex;
    flex-wrap: wrap;

    .uni-tag {
      margin-top: 5px;
      margin-right: 5px;
    }
  }
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/431477.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《花雕学AI》23:中文调教ChatGPT的秘诀:体验测试与通用案例,解锁无限有趣玩法!

引言&#xff1a; 你有没有想过和一台智能机器人聊天&#xff1f;你有没有想过让一台智能机器人为你创作诗歌、故事或歌曲&#xff1f;你有没有想过让一台智能机器人陪你玩游戏、学习或社交&#xff1f;如果你的答案是肯定的&#xff0c;那么你一定会对ChatGPT感兴趣。 ChatG…

Hystrix详解

前言 Hystrix基于Feign&#xff0c;想熟悉Hystrix&#xff0c;必须先熟悉Feign。 Feign&#xff08;简介和使用&#xff09;&#xff1a; Feign&#xff08;简介和使用&#xff09;_长头发的程序猿的博客-CSDN博客 Hystrix简介 hystrix对应的中文名字是“豪猪”&#xff0c…

Android开发 Camera2获取输出SurfaceTexture

目录 一、Camera2概述 1 Pipeline 2 CameraManager 3 CameraDevice 4 CameraCharacteristics 5 CameraCaptureSession 6 CaptureRequest 7 Surface 8 CaptureResult 三、Camera2的特性 1 Camera2 才支持的高级特性 2 Camera1 迁移到 Camera2 二、示例源码 一、Came…

Honggfuzz Linux arch_clone 源码阅读 (setjmp, clone)

Honggfuzz Linux arch_clone 源码阅读 &#xff08;setjmp, clone&#xff09; 阅读 Honggfuzz 系统架构相关源码&#xff0c;在创建子进程部分遇到了几个问题&#xff0c;经过研究得以解决&#xff0c;在此记录。 Source Code 代码节选自linux/arch.c&#xff0c;已添加注释&…

RabbitMq 消息可靠性问题(一) --- publisher发送时丢失

前言 消息从生产者发送到exchange, 再到 queue, 再到消费者。这个过程中有哪些有消息丢失的可能性呢&#xff1f; 发送时丢失&#xff1a; 生产者发送的消息未送达 exchange消息到达 exchange 后未到达 queue MQ 宕机&#xff0c;queue将消息丢失consumer 接收到消息后未消费…

聊聊如何运用JAVA注解处理器(APT)

什么是APT APT&#xff08;Annotation Processing Tool&#xff09;它是Java编译期注解处理器&#xff0c;它可以让开发人员在编译期对注解进行处理&#xff0c;通过APT可以获取到注解和被注解对象的相关信息&#xff0c;并根据这些信息在编译期按我们的需求生成java代码模板或…

基于DistFlow的含分布式电源配电网优化模型【IEEE39节点】(Python代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

SpringBoot【基础篇】---- SSMP整合综合案例

SpringBoot【基础篇】---- SSMP整合综合案例1. 模块创建2. 实体类开发3. 数据层开发----基于CRUD查看MP运行日志查看 MP 的运行日志4. 数据层开发----分页功能制作5. 数据层开发----条件查询功能制作6. 业务层开发业务层快速开发7. 表现层开发8. 表现层消息一致性处理9. 前后端…

STC32G单片机内置ADC及应用编程

一 STC32G单片机内置ADC模块简介 STC32G单片机内部集成了一个12位高速ADC转换器&#xff0c;ADC的最高时钟频率为系统频率的1/2。其输入通道多达15个&#xff08;第15通道为专门测量内部1.19V参考信号源的通道&#xff09;&#xff0c;可分时切换使用。 STC15系列单片机内置AD…

AES加密

来源&#xff1a;链接: b站up主可厉害的土豆 &#xff08;据评论区说图片中有计算错误&#xff0c;但是过程是对的。只是了解过程问题不大&#xff0c;专门研究这一块的话自己可以看视频算一下&#xff09; 准备 首先&#xff0c;明文是固定长度 16字节 128位。 密钥长度可以…

C++语法(18)---- set和map

C语法&#xff08;17&#xff09;---- 二叉搜索树_哈里沃克的博客-CSDN博客https://blog.csdn.net/m0_63488627/article/details/130174864 目录 1.set的介绍 1.set使用 1.基本结构 2.insert 3.erase 4.find 5.count 2.multiset 1.count 2.find 2.map的介绍 1.map …

zookeeper + kafka集群搭建详解

目录 1.消息队列介绍 1.为什么需要消息队列 &#xff08;MO&#xff09; 2.使用消息队列的好处 3.消息队列的两种模式 2.Kafka相关介绍 1.Kafka定义 2.Kafka简介 3. Kafka的特性 3.Kafka系统架构 1. Broker&#xff08;服务器&#xff09; 2. Topic&#xff08;一个队…

GaussDB数据库存储过程介绍

文章目录一、前言二、GaussDB中的定义三、存储过程的使用场景四、存储过程的使用优缺点五、存储过程的示例及示例解析1、GaussDB存储过程语法格式2、GaussDB存储过程语法示例3、存储过程的调用方法七、总结一、前言 华为云数据库GaussDB是一款高性能、高安全性的云原生数据库&…

链表基础知识

1.链表必知必会 什么是链表? 链表是一种通过指针串联在一起的线性结构&#xff0c;每一个节点由两部分组成&#xff0c;一个是数据域一个是指针域&#xff08;存放指向下一个节点的指针&#xff09;&#xff0c;最后一个节点的指针域指向null&#xff08;空指针的意思&#…

23北京邮电大学备考经验

目录【写在前面】本科成绩择校历程英语复习数学复习政治复习专业课复习其它建议笔记复盘压力处理恋爱关系【写在最后】【写在前面】 初试成绩&#xff1a; 本科成绩 总体&#xff1a;浙江某双非学校的软件工程专业、综合测评成绩班级前两名、浙江省省级优秀毕业生、发表过论…

【Node】Node.js 资源汇总推荐

【导读】&#xff1a;Node.js 是一个开源、跨平台的&#xff0c;用于编写服务器和命令行的 JavaScript 运行时工具。awesome-nodejs 是sindresorhus发起维护的 Node.js 资源列表&#xff0c;内容包括&#xff1a;命令行工具、日志、调试、HTTP、构建工具、文件系统、模板、Web …

Elasticjob(2.1.4) failover 、misfire及执行线程池分析

Failover 当设置failover为true时候&#xff0c;elasticjob 集群通过zookeeper 的event watcher 监听是否有instance 丢失&#xff0c;然后对丢失instance 对应的分片进行立即执行。重复一下&#xff0c;failover是立即执行&#xff0c;不是按crontab时间来触发&#xff0c;这…

基于RDF本体模型和图数据库实现知识查询与推理

基于RDF本体模型和图数据库实现知识查询与推理 基于RDF本体模型和图数据库实现知识查询与推理一、案例本体模型解释二、数据构建与查询 Here’s the table of contents: 基于RDF本体模型和图数据库实现知识查询与推理 本文主要使用ONgDB图数据库和Neosemantics组件&#xff0c;…

自建个人音乐播放器Navidrome - 内网穿透实现在外随时访问

文章目录 1. 前言2. Navidrome网站搭建2.1 Navidrome下载和安装2.1.1 安装并添加ffmpeg2.1.2下载并配置Navidrome2.1.3 添加Navidrome到系统服务 2.2. Navidrome网页测试 3. 本地网页发布3.1 cpolar的安装和注册3.2 Cpolar云端设置3.3 Cpolar本地设置 4. 公网访问测试5. 结语 转…

【Android实战开发】flutter实现网络请求的方法示例

Flutter网络请求使用的是Dio。Dio是一个强大易用的dart http请求库&#xff0c;支持Restful API、FormData、拦截器、请求取消、Cookie管理、文件上传/下载……. Flutter json数据解析是使用了json_serializable package包。它是一个自动化源代码生成器&#xff0c;可以为我们…