搜索功能+上键下键+存储历史搜索

2024-01-29 18:48

本文主要是介绍搜索功能+上键下键+存储历史搜索,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

直接上代码

List.vue组件
<template><div><input type="text" placeholder="请输入您要查询的数据" v-model="title" @input="search()"@keyup.enter="add()"@keyup.up="up()"@keyup.down="down()"><!-- 给input框绑定一个v-model用来接收输入的数据 给他一个input事件--><ul><li v-for="(e,i) in lists" :key="i" @click="save(i)" @mousemove="move(i)" :class="{red:num==i}"><!-- 循环遍历出来查找的数据 -->{{e.title}}</li></ul><h3>历史搜索</h3><ul><li v-for="(e,i) in lishi" :key="i"><span>{{e.title}}</span></li></ul></div>
</template><script>
export default {data(){return{title:"",list:[//随便写几个数据{ id: 1, title: "想和有趣的人一起浪费人生" },{ id: 2, title: "vue的小案列" },{ id: 3, title: "nodeJs" },{ id: 4, title: "微信小程序" },{ id: 5, title: "react" },{ id: 6, title: "仓库管理" },{ id: 7, title: "vuex" },{ id: 8, title: "redux" },{ id: 9, title: "router" },{ id: 10, title: "牛奶1" },{ id: 10, title: "牛奶2" },{ id: 10, title: "牛奶3" },{ id: 10, title: "牛奶4" },{ id: 10, title: "牛奶5" },{ id: 10, title: "牛奶6" },{ id: 10, title: "牛奶7" },{ id: 10, title: "牛奶8" },{ id: 10, title: "牛奶9" },{ id: 10, title: "牛奶10" }],lists:[],//历史搜索lishi:JSON.parse(localStorage.getItem("lishi"))||[],num:0//对应的下标}},methods:{search(){this.lists=[];//每次查找先把上次查找的清空if(this.title=="")//判断输入框是否输入内容,如果没有return false 结束{return false;}for(var i in this.list){if(this.list[i].title.indexOf(this.title) >= 0) //循环判断如果我们模拟的数据中包含我的input框输入的内容 则添加新数组里面 然后遍历出来{this.lists.push(this.list[i])}}},add(){//当点击回车的时候页面跳转 对应搜索记录var obj={title:this.title}this.lishi.push(obj);this.$router.push("/details?title="+this.title)localStorage.setItem("lishi",JSON.stringify(this.lishi))this.title=""  },save(i){var obj={title:this.lists[i].title}this.lishi.push(obj);this.$router.push("/details?title="+this.lists[i].title)localStorage.setItem("lishi",JSON.stringify(this.lishi))// this.title=""  },move(i){this.num=i;//this.title=this.lists[i].title},up(){this.num--;if(this.num<0){this.num=this.lists.length-1;}this.title=this.lists[this.num].title},down(){this.num++;if(this.num>this.lists.length-1){this.num=0}this.title=this.lists[this.num].title}}
}
</script><style lang="scss" scoped>
.red{background: #eee;
}
</style>

Details.vue组件

<template><div>跳转页面</div>
</template><script>
export default {}
</script><style lang="scss" scoped></style>

这篇关于搜索功能+上键下键+存储历史搜索的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/657858

相关文章

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

hdu1240、hdu1253(三维搜索题)

1、从后往前输入,(x,y,z); 2、从下往上输入,(y , z, x); 3、从左往右输入,(z,x,y); hdu1240代码如下: #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#inc

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

hdu 4517 floyd+记忆化搜索

题意: 有n(100)个景点,m(1000)条路,时间限制为t(300),起点s,终点e。 访问每个景点需要时间cost_i,每个景点的访问价值为value_i。 点与点之间行走需要花费的时间为g[ i ] [ j ] 。注意点间可能有多条边。 走到一个点时可以选择访问或者不访问,并且当前点的访问价值应该严格大于前一个访问的点。 现在求,从起点出发,到达终点,在时间限制内,能得到的最大

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.