除了三目运算,你还知道其余的装逼姿式吗?留言走你~~javascript
单行简洁的代码很难维护(有时甚至难以理解),但这并不能阻止广大攻城狮们脑洞,在编写简洁的代码后得到必定的知足感。java
如下我最近的一些收藏javascript
精简代码集合。它们均可以在你的开发控制台中运行,你能够从控制台中查看运行结果。同时,我但愿你能在评论中分享一些本身的藏品!面试
建立过去七天的数组,若是将代码中的减号换成加号,你将获得将来7天的数组集合数组
// 建立过去七天的数组 [...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days)); 复制代码
在原型设计时常常使用的建立ID功能。可是我在实际项目中看到有人使用它。其实这并不安全安全
// 生成长度为11的随机字母数字字符串 Math.random().toString(36).substring(2); // hg7znok52x 复制代码
这个获取URL的查询参数代码,是我见过最精简的QAQ
markdown
?foo=bar&baz=bing => {foo: bar, baz: bing}
dom
// 获取URL的查询参数 q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q; 复制代码
经过一堆HTML,您能够建立一个本地时间,其中包含您能够一口气读出的源代码,它每秒都会用当前时间更新页面函数
// 建立本地时间 <body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10,19))"></body> 复制代码
随机更改数组元素顺序,混淆数组spa
// 随机更改数组元素顺序,混淆数组 (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'); 复制代码
这是一个臭名昭著的面试题,让你写出他的运行结果,受不了~
for(i=0;++i<101;console.log(i%5?f||i:f+'Buzz'))f=i%3?'':'Fizz' 复制代码
这是一个原生的JS函数可是很是简洁,Set接受任何可迭代对象,如数组[1,2,3,3],并删除重复项
// 数组去重 [...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` `)() 复制代码
这是它的打印结果: