网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

30秒就能理解的JavaScript优秀代码是怎样的

今天就跟大家聊聊有关30秒就能理解的JavaScript优秀代码是怎样的,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

安顺网站制作公司哪家好,找创新互联建站!从网页设计、网站建设、微信开发、APP开发、响应式网站等网站项目制作,到程序开发,运营维护。创新互联建站公司2013年成立到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联建站

30秒就能理解的JavaScript优秀代码是怎样的

今天要和大家分享一个项目,里面精心收集了大量有用的JavaScript代码片段,让你能够在极短的时间内可以理解使用它们,分为日期、节点、功能模块等部分,你可以直接将文件的这些代码直接导入到你的的文本编辑器(VSCode,Atom,Sublime)。

30秒就能理解的JavaScript优秀代码是怎样的

这个项目在Github上十分受欢迎,目前标星 71.3K,累计分支  7.9K(Github地址:https://github.com/30-seconds/30-seconds-of-code)

下面还是一起来看看这个项目里都有哪些代码段吧:

数组:arrayMax

返回数组中的最大值。将Math.max()与扩展运算符 (...) 结合使用以获取数组中的最大值。

const arrayMin = arr => Math.min(...arr); // arrayMin([10, 1, 5]) -> 1

浏览器:bottomVisible

如果页的底部可见, 则返回true,  否则为false。使用scrollY、scrollHeight和clientHeight来确定页面底部是否可见。

const bottomVisible = () => document.documentElement.clientHeight + window.scrollY >= document.documentElement.scrollHeight || document.documentElement.clientHeight; // bottomVisible() -> true

日期:getDaysDiffBetweenDates

返回两个日期之间的差异 (以天为值)。计算Date对象之间的差异 (以天为值)。

const getDaysDiffBetweenDates = (dateInitial, dateFinal) => (dateFinal - dateInitial) / (1000 * 3600 * 24); // getDaysDiffBetweenDates(new Date("2017-12-13"), new Date("2017-12-22")) -> 9

函数:chainAsync

链异步函数,循环遍历包含异步事件的函数数组, 当每个异步事件完成时调用next。

const chainAsync = fns => { let curr = 0; const next = () => fns[curr++](next); next(); }; /* chainAsync([   next => { console.log('0 seconds'); setTimeout(next, 1000); },   next => { console.log('1 second');  setTimeout(next, 1000); },   next => { console.log('2 seconds'); } ]) */

数学:arrayAverage

返回数字数组的平均值。使用Array.reduce()将每个值添加到累加器中, 并以0的值初始化, 除以数组的length。

const arrayAverage = arr => arr.reduce((acc, val) => acc + val, 0) / arr.length; // arrayAverage([1,2,3]) -> 2

节点:JSONToFile

将 JSON 对象写入文件。使用fs.writeFile()、模板文本和JSON.stringify()将json对象写入.json文件。

const fs = require('fs'); const JSONToFile = (obj, filename) => fs.writeFile(`${filename}.json`, JSON.stringify(obj, null, 2)) // JSONToFile({test: "is passed"}, 'testJsonFile') -> writes the object to 'testJsonFile.json'

对象:cleanObj

移除从 JSON 对象指定的属性之外的任何特性。使用Object.keys()方法可以遍历给定的 json 对象并删除在给定数组中不是included  的键。另外, 如果给它一个特殊的键 (childIndicator), 它将在里面深入搜索, 并将函数应用于内部对象。

const cleanObj = (obj, keysToKeep = [], childIndicator) => { Object.keys(obj).forEach(key => { if (key === childIndicator) { cleanObj(obj[key], keysToKeep, childIndicator); } else if (!keysToKeep.includes(key)) { delete obj[key]; } }) } /*   const testObj = {a: 1, b: 2, children: {a: 1, b: 2}}   cleanObj(testObj, ["a"],"children")   console.log(testObj)// { a: 1, children : { a: 1}}

以上举的这些示例还只是冰山一角,如果你对这个项目感兴趣就赶紧马克起来。

看完上述内容,你们对30秒就能理解的JavaScript优秀代码是怎样的有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注创新互联行业资讯频道,感谢大家的支持。


标题名称:30秒就能理解的JavaScript优秀代码是怎样的
标题URL:http://bjjierui.cn/article/gdishd.html

其他资讯