返回一个键盘(惊呆了)

这是一个很难看懂的简洁代码,但是运行后你会惊呆的,他竟然返回一个图形键盘

  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` `)()

有趣js - 图1

创建数组

  1. [...Array(3).keys()]; // [0,1,2]
  1. Array(5).fill(0); // [0,0,0,0,0]

数组去重

  1. let arr = [1,2,3,1,3,5];
  2. [...new Set(arr)]; // [1, 2, 3, 5]

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

  1. // 生成随机十六进制代码 如:'#c618b2'
  2. '#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');// "#e72450"等等

数组混淆

  1. let a = (arr) => arr.slice().sort(() => Math.random() - 0.5)
  2. let b = a([1,2,3,4,5])
  3. console.log(b) // [3, 2, 4, 5, 1]

本地时间

  1. new Date().toLocaleString().slice(10,19) // "下午5:13:24"

获取URL的查询参数

  1. // 获取URL的查询参数
  2. q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;
  3. eg https://www.jianshu.com/p/5a0b560462f2?utm_campaign=maleskine&utm_content=note
  4. 返回:{utm_campaign: "maleskine", utm_content: "note"}

生成随机ID

  1. // 生成长度为11的随机字母数字字符串
  2. Math.random().toString(36).substring(2);
  3. // snije387cgg

参考

  1. JS 无形装逼,最为致命 - 爱前端不爱恋爱的文章 - 知乎 https://zhuanlan.zhihu.com/p/65445443