您现在的位置是:首页 > Javascript
当前栏目
10个JS精简代码无形集合,最为致命,记得收藏好
2023-03-14 09:41:27 时间
本文转载自微信公众号「小明菜市场」,作者小明菜市场。转载本文请联系小明菜市场公众号。
日历
创建过去七天的数组,如果把代码中的减号换成加号,将会得到未来7天的数组集合。
- // 创建过去七天的数组
- [...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));
生成随机 ID
在原型设计时需要经常使用创建 ID的功能,但是我在实际项目中看到有人使用,其实这相当不安全
- // 生成长度为11的随机字母数字字符串
- Math.random().toString(36).substring(2);
- // hg7znok52x
获取 URL 的查询参数
获取URL中的查询参数。
- // 获取URL的查询参数
- q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;
获取本地时间
通过一堆js代码,可以获取到本地的时间
- // 创建本地时间
- <body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10,19))"></body>
数组混淆
用于随机更改数组中元素的顺序
- // 随机更改数组元素顺序,混淆数组
- (arr) => arr.slice().sort(() => Math.random() - 0.5)
- /*
- let a = (arr) => arr.slice().sort(() => Math.random() - 0.5)
- let b = a([1,2,3,4,5])
- console.log(b)
- */
生成随机的颜色
用于生成随机的颜色
- // 生成随机十六进制代码 如:'#c618b2'
- '#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');
你知道这份代码运行的结果吗?
- for(i=0;++i<101;console.log(i%5?f||i:f+'Buzz'))f=i%3?'':'Fizz'
数组去重
使用原生的方法,使得数组去重
- // 数组去重
- [...new Set(arr)]
创建一个特定大小的数组
- [...Array(3).keys()]
- // [0, 1, 2]
这个返回什么?
你一定想不到,这个会返回一个键盘
- // 用字符串返回一个键盘图形
- (_=>[..."`1234567890-=~~QWERTYUIOP[]\~ASDFGHJKL;'~~ZXCVBNM,./~"].map(x=>(o+=`/${b='_'.repeat(w=x<y?2:' 667699'[x=["BS","TAB","CAPS","ENTER"][p++]||'SHIFT',p])}\|`,m+=y+(x+' ').slice(0,w)+y+y,n+=y+b+y+y,l+=' __'+b)[73]&&(k.push(l,m,n,o),l='',m=n=o=y),m=n=o=y='|',p=l=k=[])&&k.join`
- `)()
相关文章
- 12 个 GitHub 上超火的 JavaScript 项目,找到写 JavaScript 的灵感!
- 一篇文章带你了解SVG <path> 路径
- Mybatis是如何解析配置文件的?看完终于明白了
- 如何使用Promise.race() 和 Promise.any() ?
- 推荐一款功能强大的工具包
- Node.js 服务性能翻倍的秘密(一)
- 黄道十二宫杀手密码51年后被破解,来自两位程序员和数学家合作
- 鱼和熊掌兼得:Next.js 混合渲染
- 本该提高效率的组件库,最后为什么成了效率杀手?
- Node.js 服务性能翻倍的秘密之一
- 9个好用的JavaScript小技巧
- 手把手教你用Javascript制作随机星星效果图
- 17个你可能还不知道 JS 技巧!
- 这个 29.7 K 的剪贴板 JS 库有点东西!
- 如何搭积木式的快速开发H5页面?
- 配置 Spring Batch 批处理失败重试
- 2020征文-TV「续3.1.1 文本组件」不需要背景图,自定义绘制会更好
- 非Spring管理Bean如何添加AOP呢?
- 基于Vue的前端架构,我总结15点经验
- 一位资深竞争性程序员给你推荐的5大优秀竞争性编程的C ++库