WebApi入门第八章(模拟百度搜索框 )

body {

font-size: 20px;

}

.box {

width: 600px;

height: 40px;

margin: 200px auto;

position: relative;

}

#txt {

width: 498px;

height: 38px;

border: 1px solid #ccc;

font-size: 20px;

}

#search {

width: 100px;

height: 40px;

}

#keywords {

position: absolute;

top: 40px;

left: 0;

background-color: #6cf;

list-style: none;

width: 500px;

}

li {

line-height: 24px;

}

思路分析


思路分析

补充技术:用户输入的事件 oninput onkeyup onkeydown

只要用户输入内容:就会触发事件

  1. 获取事件源:#txt

  2. 确定事件类型:oninput

  3. 事件处理

3.1 获取用户输入的数据:input框的value属性

3.2 用户每输入多一个内容(或者少):应该先清空原来匹配的结果:ul.innerHTML = '';

3.3 安全处理:用户输入的数据,有可能带空格,一般需要帮助用户去除两边的空格:目标字符串.trim():去除目标两边的空格

3.4 安全处理:如果用户输入的字符串是空的(没有输入):不需要进行服务器处理(下一步没有必要执行):结束事件函数;return

3.5 去服务器匹配数据:但是不是去数组中找,而是遍历数组:看数组的元素中是否包含用户输入的关键字

3.5.1 判定:词条中是否包含用户输入的关键字:词条.indexOf(关键字) != -1 :包含关键字

3.5.2 将关键字放到li中,放到ul#keywords下

3.5.2.1 创建li:document.createElement('li')

3.5.2.2 添加内容:li.innerText = 词条

3.5.2.3 将li放到ul中

完整代码


Document

相关推荐
t***54425 分钟前
如何配置Orwell Dev-C++使用Clang
开发语言·c++
CoderCodingNo32 分钟前
【信奥业余科普】C++ 的奇妙之旅 | 13:为什么 0.1+0.2≠0.3?——解密“爆int”溢出与浮点数精度的底层原理
开发语言·c++
kongba0072 小时前
项目打包 Python Flask 项目发布与打包专家 提示词V1.0
开发语言·python·flask
froginwe112 小时前
C 语言测验
开发语言
今夕资源网2 小时前
powershell工具包 安装升级脚本并设置UTF-8 环境快捷方式创建 将powershell的编码默认改为UTF-8
开发语言·utf-8·powershell·utf-8编码·powershell7·powershell5·设置utf-8编码
机器视觉知识推荐、就业指导3 小时前
Qt:真正的门槛不是入门,而是维护
开发语言·qt
hhb_6183 小时前
Dylan 语言核心特性与工程实践深度解析
开发语言·c#
无巧不成书02184 小时前
零基础Java网络编程全解:从核心概念到Socket实战,一文打通Java网络通信
java·开发语言·网络
MXN_小南学前端4 小时前
watch详解:与computed 对比以及 Vue2 / Vue3 区别
前端·javascript·vue.js
饭小猿人4 小时前
Flutter实现底部动画弹窗有两种方式
开发语言·前端·flutter