如何在卡片搜索无结果时显示“未找到卡片”提示

如何在卡片搜索无结果时显示“未找到卡片”提示

本文旨在解决卡片搜索功能中,当没有匹配结果时,“未找到卡片”提示显示不准确的问题。通过优化javascript逻辑,我们展示了如何首先隐藏所有卡片,然后根据搜索过滤结果来精确显示匹配卡片或“无内容”提示,确保用户体验的准确性和流畅性。

在构建动态网页应用时,搜索过滤功能是常见的需求。例如,在卡片(card)布局中,用户输入搜索词后,页面会实时显示匹配的卡片,并在无匹配项时提示“未找到卡片”。然而,如果JavaScript逻辑处理不当,可能会导致“未找到卡片”的提示在仍有匹配项时错误显示,或在无匹配项时未能及时显示。本教程将详细介绍如何通过改进JavaScript代码,实现一个健壮且用户友好的卡片搜索无结果提示功能。

核心问题分析

原始的JavaScript代码在处理搜索结果时,其主要逻辑是在遍历每张卡片时,如果卡片不匹配搜索条件,就立即显示“未找到内容”的提示。这种逐个判断的方式会导致一个问题:只要循环中有一张卡片不匹配,提示就会被显示,即使其他卡片是匹配的。正确的逻辑应该是,在所有卡片都被检查完毕后,再根据最终的匹配结果来决定是否显示“未找到内容”的提示。

优化后的JavaScript搜索逻辑

为了解决上述问题,我们需要调整JavaScript的执行流程。核心思想是:

在每次搜索开始时,首先隐藏所有卡片。遍历所有卡片,找出所有符合搜索条件的卡片。只显示这些符合条件的卡片。最后,根据符合条件的卡片数量,决定是否显示“未找到内容”的提示。

以下是优化后的JavaScript代码:

function myFunction() {  // 获取输入框和“无内容”提示元素  const input = document.getElementById("myFilter");  const noContent = document.getElementById("no-content");  // 获取搜索过滤值,并转换为大写以便进行不区分大小写的匹配  const filter = input.value.toUpperCase();  // 获取卡片容器和所有卡片元素  const cardContainer = document.getElementById("myItems");  // 将HTMLCollection转换为数组,以便使用forEach和filter等数组方法  const cards = Array.from(cardContainer.getElementsByClassName("blog-card"));  // 步骤1: 首先隐藏所有卡片  cards.forEach(card => card.style.display = "none");  // 步骤2: 筛选出匹配搜索条件的卡片  const matchingCards = cards.filter(    card => card.querySelector(".card-title").innerText.toUpperCase().includes(filter)  );  // 步骤3: 显示所有匹配的卡片  matchingCards.forEach(card => card.style.display = "block");  // 步骤4: 根据匹配卡片的数量,决定是否显示“无内容”提示  // 如果没有匹配的卡片,则显示“无内容”提示,否则隐藏  noContent.style.display = (matchingCards.length === 0 ? "flex" : "none");}

HTML结构和初始状态

为了配合JavaScript逻辑,HTML结构需要包含一个搜索输入框、一个卡片容器以及一个用于显示“无内容”提示的元素。其中,“无内容”提示元素应在初始状态下被隐藏。

STORYD STORYD

帮你写出让领导满意的精美文稿

STORYD 164 查看详情 STORYD

如何在卡片搜索无结果时显示“未找到卡片”提示

Tips to keep your car running.

如何在卡片搜索无结果时显示“未找到卡片”提示

Auto Repair

Did you know that in 2021 there were 201,927 active dentists in the United States? That means there is a ratio of approximately 61 dentists per 100,000 people in the country…

there are no more blog post with this term

注意事项:

no-content 元素通过 style=”display: none;” 在HTML中初始化为隐藏状态。JavaScript将根据搜索结果动态控制其显示。onkeyup=”myFunction()” 事件监听器确保每次用户在输入框中输入或删除字符时,搜索功能都会被触发。

CSS样式

CSS样式主要用于美化卡片和搜索框,以及确保“无内容”提示在显示时能够居中且清晰。以下是关键的CSS样式:

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@500&family=Open+Sans:wght@700&display=swap');/* 输入框容器样式 */.input-container {  display: flex;  justify-content: center;  width: 100%;}.input-container .search-imput {  margin: 20px;  width: 50%;  height: 40px;  border-radius: 30px;  border: 2px solid #6F77E9;}::placeholder {  color: #161663;  font-weight: bold;  text-align: center;  font-size: 1em;}/* 卡片容器样式 */.card-container {  display: flex;  flex-wrap: wrap;  justify-content: center;  flex-direction: row;  margin: 50px;  width: 100%px; /* 注意:此处的px应为单位,例如 100% */}/* 单个卡片样式 */.blog-card {  width: 490px;  height: 470px;  margin: 15px;  border-radius: 20px;  -webkit-box-shadow: 0px 0px 4px 0px rgba(22, 22, 99, 0.30);  box-shadow: 0px 0px 4px 0px rgba(22, 22, 99, 0.30);}/* 卡片内部元素样式 */.blog-card p {  font-family: 'Montserrat', sans-serif;  margin: 0px;  padding: 0px 30px;}.blog-card .blog-card-head img {  padding: 20px;  width: 92%;  border-radius: 30px;}.blog-card .blog-card-head h2 {  font-family: 'Open Sans', sans-serif;  text-align: center;  color: #161663;}.blog-card .blog-card-footer,.blog-card .blog-card-body {  display: flex;  align-items: center;}.blog-card .blog-card-body {  padding: 0px 20px;}.blog-card .blog-card-body img {  width: 50px;}.blog-card .blog-card-body h1 {  font-family: 'Open Sans', sans-serif;  font-size: 20px;  color: #161663;}.blog-card .blog-card-footer {  padding: 0px 20px;}.blog-card .blog-card-footer a {  display: flex;  justify-content: center;  align-items: center;  font-family: 'Montserrat', sans-serif;  text-decoration: none;}.blog-card .blog-card-footer img {  margin: 10px;  width: 30px;}/* 无内容提示区域样式 */.no-content {  width: 100vw;  height: 50vh;  display: flex; /* 使用flex布局方便居中 */  justify-content: center; /* 水平居中 */  align-items: center; /* 垂直居中 */}.no-content h1 {  font-size: 20px;  padding: 0px 20px;  font-family: 'Montserrat', sans-serif;  color: #161663;}

总结

通过上述优化,我们实现了一个更加准确和用户友好的卡片搜索功能。关键改进在于将“无内容”提示的显示逻辑从循环内部移到循环之后,并利用现代JavaScript的数组方法(如forEach和filter)来清晰地分离隐藏、筛选和显示卡片的过程。这种方法不仅解决了原始代码中提示显示不准确的问题,也提高了代码的可读性和维护性。在开发动态内容过滤功能时,始终建议采用这种先整体处理、后局部调整的策略,以确保逻辑的正确性和用户体验的流畅性。

以上就是如何在卡片搜索无结果时显示“未找到卡片”提示的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/849042.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月27日 16:29:07
下一篇 2025年11月27日 16:35:05

相关推荐

  • 用了一个星期的S25 Ultra,我有这些体验想和你分享一下

    三星galaxy s25 ultra:轻薄机身与ai赋能的完美融合 “均衡的手机千篇一律,有趣的手机万里挑一。”在手机市场同质化竞争日益激烈的今天,这句话或许道出了许多消费者的内心呼声。然而,三星Galaxy S系列却始终凭借其均衡的配置和体验,成为市场上的佼佼者。而全新发布的三星Galaxy S2…

    2025年12月6日 硬件教程
    000
  • 荣耀开始安排 6.3-6.5 英寸中小尺寸机型?两款新机曝光

    荣耀将推出中小尺寸屏幕新机型!据数码闲聊站爆料,荣耀计划发布两款中端机型,分别采用6.5英寸左右1.5k直屏和6.78英寸左右1.5k等深四曲屏,均配备7000毫安时以上大电池,并搭载骁龙7 gen 4处理器(sm7750),预计上半年发布。 爆料显示,荣耀正在积极布局中小尺寸手机市场,目前已启动6…

    2025年12月6日 硬件教程
    000
  • 云闪付怎么快速赚取积点_云闪付积点快速获取方法

    通过微信小程序用云闪付支付可日赚692积点;62VIP会员消费满10元返积点,月上限3000;转账超1000元得2积点,还款超100元得10积点,每月各限3笔;扫本人收款码支付5元以上每笔得10积点,日限3笔;改定位至杭州领“浙里有优惠”活动卡可得2025积点。 如果您在使用云闪付时希望快速积累积点…

    2025年12月6日 软件教程
    000
  • AO3镜像站备用镜像网址_AO3镜像站快速访问官网

    AO3镜像站备用网址包括ao3mirror.com和xiaozhan.icu,当主站archiveofourown.org无法访问时可切换使用,二者均同步更新内容并支持多语言检索与离线下载功能。 AO3镜像站备用镜像网址在哪里?这是不少网友都关注的,接下来由PHP小编为大家带来AO3镜像站快速访问官…

    2025年12月6日 软件教程
    000
  • 天猫app淘金币抵扣怎么使用

    在天猫app购物时,淘金币是一项能够帮助你节省开支的实用功能。掌握淘金币的抵扣使用方法,能让你以更实惠的价格买到心仪商品。 当你选好商品并准备下单时,记得查看商品页面是否支持淘金币抵扣。如果该商品支持此项功能,在提交订单的页面会明确显示相关提示。你会看到淘金币的具体抵扣比例——通常情况下,淘金币可按…

    2025年12月6日 软件教程
    000
  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    000
  • Pages怎么协作编辑同一文档 Pages多人实时协作的流程

    首先启用Pages共享功能,点击右上角共享按钮并选择“添加协作者”,设置为可编辑并生成链接;接着复制链接通过邮件或社交软件发送给成员,确保其使用Apple ID登录iCloud后即可加入编辑;也可直接在共享菜单中输入邮箱地址定向邀请,设定编辑权限后发送;最后在共享面板中管理协作者权限,查看实时在线状…

    2025年12月6日 软件教程
    000
  • 咸鱼遇到“只退款不退货”的买家怎么办_咸鱼处理只退款不退货方法

    先与买家协商解决,要求其按规则退货退款,并保留聊天记录;若协商无效,申请平台介入并提交发货、签收及沟通等证据;若平台处理不利且金额较大,可依法提起民事诉讼,主张买家违反《民法典》合同规定,追回货款。 如果您在咸鱼平台出售手机后,买家申请“仅退款不退货”,这可能导致您既损失商品又损失资金。以下是应对该…

    2025年12月6日 软件教程
    000
  • 怎么下载安装快手极速版_快手极速版下载安装详细教程

    1、优先通过华为应用市场搜索“快手极速版”,确认开发者为北京快手科技有限公司后安装;2、若应用商店无结果,可访问快手极速版官网下载APK文件,需手动开启浏览器的未知来源安装权限;3、也可选择豌豆荚、应用宝等可信第三方平台下载官方版本,核对安全标识后完成安装。 如果您尝试在手机上安装快手极速版,但无法…

    2025年12月6日 软件教程
    000
  • 哔哩哔哩的视频卡在加载中怎么办_哔哩哔哩视频加载卡顿解决方法

    视频加载停滞可先切换网络或重启路由器,再清除B站缓存并重装应用,接着调低播放清晰度并关闭自动选分辨率,随后更改播放策略为AVC编码,最后关闭硬件加速功能以恢复播放。 如果您尝试播放哔哩哔哩的视频,但进度条停滞在加载状态,无法继续播放,这通常是由于网络、应用缓存或播放设置等因素导致。以下是解决此问题的…

    2025年12月6日 软件教程
    000
  • 淘特app怎么用微信支付

    在使用淘特app购物时,不少用户都希望可以像平时一样用微信支付完成付款。然而,淘特目前并不支持微信支付直接结算。不过,通过一些变通方式,依然可以实现用微信完成付款的便捷体验。 你可以先像平常一样在淘特app内挑选心仪的商品,并加入购物车。进入结算页面后,虽然系统默认提供支付宝、银行卡等支付选项,但此…

    2025年12月6日 软件教程
    000
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    000
  • Linux中如何安装Nginx服务_Linux安装Nginx服务的完整指南

    首先更新系统软件包,然后通过对应包管理器安装Nginx,启动并启用服务,开放防火墙端口,最后验证欢迎页显示以确认安装成功。 在Linux系统中安装Nginx服务是搭建Web服务器的第一步。Nginx以高性能、低资源消耗和良好的并发处理能力著称,广泛用于静态内容服务、反向代理和负载均衡。以下是在主流L…

    2025年12月6日 运维
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    000
  • 华为新机发布计划曝光:Pura 90系列或明年4月登场

    近日,有数码博主透露了华为2025年至2026年的新品规划,其中pura 90系列预计在2026年4月发布,有望成为华为新一代影像旗舰。根据路线图,华为将在2025年底至2026年陆续推出mate 80系列、折叠屏新机mate x7系列以及nova 15系列,而pura 90系列则将成为2026年上…

    2025年12月6日 行业动态
    000
  • 菜鸟app的语音助手怎么唤醒_菜鸟app语音助手使用方法

    检查菜鸟App麦克风及后台运行权限;2. 在App内开启语音助手功能;3. 通过首页麦克风图标手动唤醒;4. 更新App至最新版本以确保功能正常。 如果您在使用菜鸟App时希望快速获取快递信息或执行相关操作,但发现语音助手无法响应,可能是由于唤醒功能未正确设置。以下是解决此问题的步骤: 本文运行环境…

    2025年12月6日 软件教程
    000
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • 高德地图收藏的地点无法删除怎么办 高德地图收藏管理与操作方法

    首先确认是否在正确页面操作并拥有编辑权限,再检查账号登录状态、网络连接及应用缓存问题。打开高德地图→“我的”→“收藏”,点击地点后的“…”选择“删除”或长按删除。若无法删除,可能是账号错误、共享内容无权修改、网络不佳或缓存异常。可尝试清除缓存、更新App、重启设备。仍无效时联系官方客服解决。 高德地…

    2025年12月6日 软件教程
    000
  • 方正证券新股中签后怎么缴款_方正证券新股中签缴款教程

    中签后需在T+2日16:00前备足资金,方正证券将自动扣款。通过小方APP、短信或中签查询功能确认结果,缴款金额为中签股数×发行价,可用账户余额、卖股资金或银证转账充值,建议多存几十元作缓冲。系统通常于T+2日收盘后扣款,若资金不足或被其他自动交易占用导致失败,一年累计弃购3次将被限制半年打新。核心…

    2025年12月6日 软件教程
    000
  • 首款鸿蒙电脑惊艳亮相,华为重构电脑产业新格局

    华为鸿蒙电脑技术与生态沟通会隆重举行,首款鸿蒙电脑惊艳登场,这一标志性事件预示着华为在电脑领域迈出了具有深远影响的关键一步,为国产电脑产业带来了全新的革新与发展契机。 鸿蒙电脑的推出并非一朝一夕之功,而是华为经过五年精心策划的结果。在此期间,华为汇聚了超过10000名顶尖工程师,与20多家专业研究所…

    2025年12月6日 硬件教程
    000

发表回复

登录后才能评论
关注微信