這篇文章主要介紹“有哪些JS精簡代碼”,在日常操作中,相信很多人在有哪些JS精簡代碼問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”有哪些JS精簡代碼”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
日歷
創建過去七天的數組,如果把代碼中的減號換成加號,將會得到未來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` `)()
到此,關于“有哪些JS精簡代碼”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。