当前位置: 首页 > news >正文

前端面试项目细节重难点(已工作|做分享)想(八)

面试官:请你讲讲你在该项目中遇到的印象深刻的问题是什么?

答:我的回答:该项目的实现过程中我确实遇到了问题:【我会给大家整理回答思路和角度,那那么遇到这样的问题也可借鉴这种思路进行阐述】

第一层面:分析页面:【原型图如下】

60d12960403445409aaca1aa40d969aa.png 

(1)发现问题:

用户在下拉选择的搜索框搜索值David时,整个页面卡死了,不能选到用户需要的值,如下图所示:

e1319d1f08524c22a8da5900c8bcc1a7.png 

此时,打开控制台出现了一个报错信息:大概意思就是id为6的value值已经被id为5的value值使用了。

(2)分析问题:【这个才是项目重难点】

首先,找到返回数据的接口URL,并打开网络请求,根据URL找到该接口,并去预览里复制数据后粘贴到记事本里;

dce66d886bd64090b0b7b9cd4f3c12d4.png

 

然后,直接使用查找功能,分别找到id为5和id为6的value值,确实都是`David`,数据结构如下图所示:

16774429acf448f4b3794e99ee36db93.png

 

最后,定位到了原因:浏览器在渲染页面展示数据时,根据用户输入值肯定匹配到两个value值,不知道哪一个要渲染出来,所以导致用户在搜索David该值时,不知道该匹配id为5的value值还是匹配id为6的value值,就出现了搜索下拉框页面卡死问题。

(3)解决问题:

首先,既然定位到数据出了问题,不是前端导致的问题,那肯定要找上级领导反馈问题,让数据处理这个问题,一个value不能有重复出现的情况。

其次,与产品协商后,数据不能保证完全没问题,所以前端要能保证用户输入value值时,无论选项是否有重复,都得将所有匹配到的选项筛选出来,不能出现用户选不了和页面卡死的问题,效果如下图所示:

a693b37548cc47f48ab53022869483dd.png

 

第二层面:分析代码:

(4)实现思路:

当用户输入值时,只要与options中匹配到的value值都要显示出来。

(5)代码实现(实现过程):

264e69cc16f6480abc1fdc2b994e0893.png

80350d186bc54c4cafb4d7c05292c3b2.png 

2d815d9eaee14b92bddfa6da7cd28b9d.png 

54a88970251745898a0b5d389f590bdb.png 

 

 

 

 

 

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Ubuntu22.04之解决:terminal使用alt+1/alt+2/alt+3失效问题(二百三十八)
  • 自然语言处理(NLP)—— 自动摘要
  • 【手推公式】如何求SDE的解(附录B)
  • 爬虫——有道云翻译
  • QTGUI编程入门:解锁图形用户界面设计的奥秘
  • 知识图谱的应用---智能电网
  • Python使用Flask构建简单的web应用
  • 二叉树—leetcode
  • 发现 Laravel 中的 api 响应时间明显过长
  • Aptos Builder Jam 亚洲首站|见证 Aptos 公链 2024 年新突破
  • JAVA面试八股文----Mybatis
  • CSAPP Lab01——Data Lab完成思路
  • Git配置 安装及使用
  • 高通Android 12/13添加/移除不被清理后台应用
  • web学习笔记(六十四)
  • “大数据应用场景”之隔壁老王(连载四)
  • 10个确保微服务与容器安全的最佳实践
  • canvas 绘制双线技巧
  • el-input获取焦点 input输入框为空时高亮 el-input值非法时
  • HTTP中GET与POST的区别 99%的错误认识
  • idea + plantuml 画流程图
  • javascript从右向左截取指定位数字符的3种方法
  • JSONP原理
  • Kibana配置logstash,报表一体化
  • Map集合、散列表、红黑树介绍
  • MySQL QA
  • React 快速上手 - 07 前端路由 react-router
  • RxJS: 简单入门
  • 高性能JavaScript阅读简记(三)
  • 关于字符编码你应该知道的事情
  • 聊聊redis的数据结构的应用
  • 聊聊spring cloud的LoadBalancerAutoConfiguration
  • 十年未变!安全,谁之责?(下)
  • 微信小程序设置上一页数据
  • 数据可视化之下发图实践
  • # dbt source dbt source freshness命令详解
  • ### RabbitMQ五种工作模式:
  • $.extend({},旧的,新的);合并对象,后面的覆盖前面的
  • (11)MATLAB PCA+SVM 人脸识别
  • (Java入门)学生管理系统
  • (PyTorch)TCN和RNN/LSTM/GRU结合实现时间序列预测
  • (react踩过的坑)antd 如何同时获取一个select 的value和 label值
  • (二)PySpark3:SparkSQL编程
  • (接口封装)
  • (免费领源码)python#django#mysql公交线路查询系统85021- 计算机毕业设计项目选题推荐
  • (循环依赖问题)学习spring的第九天
  • (一)基于IDEA的JAVA基础12
  • (已更新)关于Visual Studio 2019安装时VS installer无法下载文件,进度条为0,显示网络有问题的解决办法
  • (转载)虚幻引擎3--【UnrealScript教程】章节一:20.location和rotation
  • .Net Web窗口页属性
  • .net 获取某一天 在当月是 第几周 函数
  • .NET 简介:跨平台、开源、高性能的开发平台
  • .NET 依赖注入和配置系统
  • .NetCore项目nginx发布
  • .net访问oracle数据库性能问题