前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >js 小技巧,无形装逼

js 小技巧,无形装逼

作者头像
Alone88
发布2019-10-22 18:06:42
5640
发布2019-10-22 18:06:42
举报
文章被收录于专栏:Alone88Alone88

日历 math random 生成 days map

日历

代码语言:javascript
复制
// 创建过去七天的数组
[...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));

// 创建未来七天的数组
[...Array(7).keys()].map(days => new Date(Date.now() + 86400000 * days));

生成随机的ID

代码语言:javascript
复制
// 生成长度为11的随机字母数字字符串
Math.random().toString(36).substring(2);
// 6i0cgykkys8

获取URL的查询参数

?foo=bar&baz=bing => {foo: bar, baz: bing}

代码语言:javascript
复制
// 获取URL的查询参数
q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;

本地时间

通过一堆HTML,您可以创建一个本地时间,其中包含您可以一口气读出的源代码,它每秒都会用当前时间更新页面

代码语言:javascript
复制
// 创建本地时间
<body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10,19))"></body>

数组混淆

代码语言:javascript
复制
// 随机更改数组元素顺序,混淆数组
(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)
*/

生成随机十六进制代码(生成随机颜色)

代码语言:javascript
复制
// 生成随机十六进制代码 如:'#c618b2'
'#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');

一个面试题

代码语言:javascript
复制
for(i=0;++i<101;console.log(i%5?f||i:f+'Buzz'))f=i%3?'':'Fizz'

数组去重

代码语言:javascript
复制
方便快捷创建特定大小的数组
[...Array(3).keys()]
// [0, 1, 2]

创建特定大小的数组

代码语言:javascript
复制
[...Array(3).keys()]
// [0, 1, 2]

返回一个键盘(惊呆了)

代码语言:javascript
复制
// 用字符串返回一个键盘图形
(_=>[..."`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`
`)()

参考:https://juejin.im/post/5cc55eb5e51d456e577f93f0

本文由 Alone88 创作,采用 知识共享署名4.0 国际许可协议进行许可 本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名 最后编辑时间为: Apr 28, 2019 at 07:58 pm

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 日历
  • 生成随机的ID
  • 获取URL的查询参数
  • 本地时间
  • 数组混淆
  • 一个面试题
  • 数组去重
  • 创建特定大小的数组
  • 返回一个键盘(惊呆了)
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档