实现原理:
利用js的 indexOf 方法可返回某个指定的字符串值在字符串中首次出现的位置。
模板中的代码
<div class="search"> <!--输入框使用的是vant的输入框组件--> <van-search @input="autoSearch" v-model="value" placeholder="请输入搜索关键词" style="width:90%; display:inline-block;" /> <span>搜索</span> </div> <!--展示数据--> <ul v-for="(item) in allArea" :key="item.communityId" > <li v-if="allNewArea.length != 0">{{ item.communityName }}</li> <li v-else>{{ item.communityName }}</li> </ul>
js代码
getAreaDetail () { // 获取数据 this.$http({ method: 'post', url: '/appProperty/getCommunity', }).then(res => { this.allArea = res.data this.allNewArea = res.data }) }, autoSearch () { // 模糊搜索加节流(500ms触发一次) var allowPass = true if (!allowPass) { return } setTimeout(() => { allowPass = false this.allArea = []; this.allNewArea.filter(item => { if (item.communityName.indexOf(this.value) !== -1) { // 此处也可使用js的 search 方法实现indexOf 一样效果 this.allArea.push(item); } }) }, 500); },
拓展
节流函数 节省流量节省内存性能的一种函数,可以理解为是一种性能优化方案
//首先定义一个全局变量 当浏览器窗口大小发生变化也就是重新计算窗口大小的时候触发 var canRun = true; window.onresize = function () { if (!canRun) { return } canRun = false//设置一个定时器进行轮询操作 setTimeout(function () {//这是要做的事情 console.log("函数节流")//最后记得重新赋值true继续让他取反 canRun = true//每隔1000毫秒也就是1秒钟就执行一次 }, 1000) }
防抖函数 当事件触发完成之后再延迟触发,并且只触发一次;如果在触发完成之前再次触发,则会再次刷新延迟
//定义方法即要做的事情 function fun(){ console.log('onresize') } //定义事件触发要执行的方法,两个参数分别是传入的要做的事情和定时器的毫秒数 function debounce (fn, delay) { //定义一个变量作为等会清除对象 var handle; //这里用到了闭包,一个函数里面return另一个函数,变量相互牵引导致垃圾回收机制不会销毁handle变量 return function () { //在这里一定要清除前面的定时器,然后创建一个新的定时器 clearTimeout(handle) //最后这个定时器只会执行一次也就是事件触发完成之后延迟500毫秒再触发(这里的变量赋值是跟定时器建立连接,进行地址赋值,一定要重新赋值给handle handle = setTimeout(function () { fn() }, delay) } } //给浏览器添加监听事件resize window.addEventListener('resize', debounce(fun, 500));
两者区别
- 防抖函数和节流函数都是用来提升性能优化及用户体验的一种方案;
- 防抖函数只会执行一次,且是最后触发的那一次,而节流函数会规律性的执行多次;
总结
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7