10個(gè)JS精簡(jiǎn)代碼無(wú)形集合,最為致命,記得收藏好
本文轉(zhuǎn)載自微信公眾號(hào)「小明菜市場(chǎng)」,作者小明菜市場(chǎng)。轉(zhuǎn)載本文請(qǐng)聯(lián)系小明菜市場(chǎng)公眾號(hào)。
日歷
創(chuàng)建過(guò)去七天的數(shù)組,如果把代碼中的減號(hào)換成加號(hào),將會(huì)得到未來(lái)7天的數(shù)組集合。
- // 創(chuàng)建過(guò)去七天的數(shù)組
 - [...Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));
 
生成隨機(jī) ID
在原型設(shè)計(jì)時(shí)需要經(jīng)常使用創(chuàng)建 ID的功能,但是我在實(shí)際項(xiàng)目中看到有人使用,其實(shí)這相當(dāng)不安全
- // 生成長(zhǎng)度為11的隨機(jī)字母數(shù)字字符串
 - Math.random().toString(36).substring(2);
 - // hg7znok52x
 
獲取 URL 的查詢參數(shù)
獲取URL中的查詢參數(shù)。
- // 獲取URL的查詢參數(shù)
 - q={};location.search.replace(/([^?&=]+)=([^&]+)/g,(_,k,v)=>q[k]=v);q;
 
獲取本地時(shí)間
通過(guò)一堆js代碼,可以獲取到本地的時(shí)間
- // 創(chuàng)建本地時(shí)間
 - <body onload="setInterval(()=>document.body.innerHTML=new Date().toLocaleString().slice(10,19))"></body>
 
數(shù)組混淆
用于隨機(jī)更改數(shù)組中元素的順序
- // 隨機(jī)更改數(shù)組元素順序,混淆數(shù)組
 - (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)
 - */
 
生成隨機(jī)的顏色
用于生成隨機(jī)的顏色
- // 生成隨機(jī)十六進(jìn)制代碼 如:'#c618b2'
 - '#' + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, '0');
 
你知道這份代碼運(yùn)行的結(jié)果嗎?
- for(i=0;++i<101;console.log(i%5?f||i:f+'Buzz'))f=i%3?'':'Fizz'
 
數(shù)組去重
使用原生的方法,使得數(shù)組去重
- // 數(shù)組去重
 - [...new Set(arr)]
 
創(chuàng)建一個(gè)特定大小的數(shù)組
- [...Array(3).keys()]
 - // [0, 1, 2]
 
這個(gè)返回什么?
你一定想不到,這個(gè)會(huì)返回一個(gè)鍵盤
- // 用字符串返回一個(gè)鍵盤圖形
 - (_=>[..."`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`
 - `)()
 















 
 
 









 
 
 
 