作者:©Iaine 万一
简介:30-day vanilla js coding challenge (30 Day Challenge)是 Wes Bos 设计的一个 30 天原生js编程挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。本项目属于第6天项目,为了更有挑战性,我尝试实现了 单词查找 的功能。Have fun with the website! ♪(^∇^*)
引言
在输入框中输入一个单词,会实时匹配现有词库中所有包含该字段的单词(以一定的样式展示),每个单词中,会高亮显示出文本输入框中输入的字段。词库为json数据,在加载页面时,异步获取而来。
项目主要知识点包括:
- 异步操作
- 数组Array对象的一些方法
- 正则表达式
- CSS transform的一些属性
项目过程
html部分
设置input标签用来输入单词,ul标签(列表标签)用来展示搜索的结果
JS部分
- 空数组直接赋值给一个
dict
变量,用来存储json数据中的词库 - 使用fetch 方法从网络中异步获取资源,解析 JSON 数据,存入数组
dict
- 利用 filter() 方法查找单词
wordToMatch
,筛选的条件是正则表达式,如果string的match(regex)方法返回不是空,则filter函数返回词库中所有wordToMatch字段的单词- 运用
filter()
过滤数组数据 - 创建正则表达式,构造过滤条件
- match方法匹配
- 运用
- 编写匹配输入的函数。在Html中显示匹配的单词,利用map方法按照原始数组元素顺序依次处理元素。
- 获取匹配数据
- 替换关键词放入高亮的标签
- 构造 HTML 标签数据
- 将匹配值的 HTML 标签放入
<ul>
中
- 编写展示匹配结果的函数
- 获取匹配数据
- 利用map方法依次处理元素,替换关键词放入高亮的标签,返回html标签数据
- 将匹配值的 HTML 标签放入
<ul>
中
- 获取两个主要 HTML 元素(
<input>
,<ul>
),给<input>
添加事件监听(change
,keyup
)
CSS部分
CSS**transform
**属性允许旋转,缩放,倾斜或平移给定元素。这是通过修改CSS视觉格式化模型的坐标空间来实现的。
项目知识点
异步操作
概念:程序执行任务时分两段进行,执行第一段任务后,执行其他任务,其他任务执行完后接着执行第二段任务。
异步操作的方法:
- 回调函数多重嵌套
缺点:出现多重嵌套,代码很容易乱成一团,无法管理,出现callback hell。
示例: 读取A文件之后,再读取B文件,之后再回到读取A文件后的操作。
1 | fs.readFile(fileA, function (err, data) { |
- Promise
它不是新的语法功能,而是一种新的写法。代码从横向发展,变成纵向发展。Promise提供then方法加载回调函数,catch方法捕捉执行过程中抛出的错误。
1 | var readFile = require('fs-readfile-promise'); |
fetch
属于Fetch API的一个全局方法。需要接受 url
作为参数,返回值是一个 Promise 对象。若请求成功,这个对象包含了(对应 Request 的)Response,但这只是一个 HTTP 响应。
一个基本的 fetch 请求设置代码如下:
1 | fetch('http://example.com/movies.json') |
这里通过网络获取一个 JSON 文件并将其打印到控制台。最简单的用法是只提供一个参数用来指明想 fetch()
到的资源路径,然后返回一个包含响应结果的 promise(一个 Response
对象)。
当然它只是一个 HTTP 响应,而不是真的 JSON。为了获取JSON的内容,我们需要使用 json()
方法(该方法返回一个将响应 body 解析成 JSON 的 promise)。
对象转换为数组
获取的资源data为对象类型,
``{a: ‘The first letter of the English and of many other …tury, wasa sound of the quality of ä (as in far).’, ab: ‘The fifth month of the Jewish year according to th…putation,coinciding nearly with August. W. Smith.’, aback: ‘Backward against the mast;-said of the sails when …uddenly checked, baffled, ordiscomfited. Dickens.’, abaft: ‘Behind; toward the stern from; as, abaft the wheelhouse. Abaftthe beam. See under Beam.’, abalone: ‘A univalve mollusk of the genus Haliotis. The shel…oast of California, clingingclosely to the rocks.’, …}`
想要转换为数组:
[0:{a: 'The first letter of the English and of many other …tury, wasa sound of the quality of ä (as in far).'}
1:{ab: 'The fifth month of the Jewish year according to th…putation,coinciding nearly with August. W. Smith.'}]
代码参考链接:https://juejin.cn/post/6844903602478120967
1 | data => Object.keys(data).forEach(v => { |
Object.keys方法是JavaScript中用于遍历对象属性的一个方法 。它传入的参数是一个对象,返回的是一个数组,数组中包含的是该对象所有的属性名。
正则表达式
概念:匹配字符串的字符组合模式
创建一个正则表达式有两种方法:
1 使用正则表达式字面量,包含在斜杠之间
2 调用RegExp
对象的构造函数
知识参考链接:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Guide/Regular_Expressions
正则表达式可以被用于 RegExp
的 exec
和 test (en-US) 方法以及 String
的 match (en-US)、replace
、search (en-US) 和 split (en-US) 方法。其中match方法是一个在字符串中执行查找匹配的String方法,返回一个数组,在未匹配到时会返回 null。
1 | // 匹配单词 |
一些数组和对象方法
17个实用的JavaScript数组和对象的方法:https://segmentfault.com/a/1190000015301183
- .filter()
创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。 - .map()
创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。 - .reduce()
对累加器和数组中的每个元素(从左到右)应用一个函数,将其减少为单个值。 - .forEach()
对数组的每个元素执行一次提供的函数。 - .some()
判断数组中的某些元素是否通过由提供的函数实现的测试。 - .every()
检查是否数组中的每个值都满足条件。 - .includes()
检查是否一个数组包含一个确定的值。 - Array.from()
这是一个可以从其他数组或者字符串中创造新array的方法。 - Objects.values()
返回一个由给定对象自己的所有可枚举属性值的数组。 - Objects.keys()
返回一个由给定对象的自身可枚举属性组成的数组。 - Object.entries()
返回一个由一个给定对象的键值对组成的数组。 - Array spread
在数组中使用扩展运算符(…)可以展开数组中的元素。 - Object spread
扩展对象允许为一个没有更改的对象添加新的属性和方法(换句话说,创建了一个新对象) - Object.freeze()
防止修改现有的对象属性或者向对象添加新的属性和值。 - Object.seal()
停止将任何新属性添加到对象,但仍允许更改现有属性。 - Object.assign()
允许将对象组合在一起。
想把我的技术文章写好一点,特意参考其他优秀人的文档,感谢未枝丫,我觉得他的文档写的不错,特意模仿,顺便挂上他的JS30挑战项目链接。
感谢阅读,有问题联系我的邮箱[email protected].