前端开发 大前端 W3Cbest

一个专注 WEB 开发的技术博客

0%

JavaScript骚操作之单行程序

单行简洁的代码很难维护(有时甚至难以理解),但这并不能阻止广大攻城狮们脑洞,在编写简洁的代码后获得一定的满足感。 以下我最近的一些收藏javascript精简代码集合。它们都可以在你的开发控制台中运行,你可以从控制台中查看运行结果。同时,我希望你能在评论中分享一些自己的藏品

日历

创建过去七天的数组,如果将代码中的减号换成加号,你将得到未来7天的数组集合

// 创建过去七天的数组
[…Array(7).keys()].map(days => new Date(Date.now() - 86400000 * days));

Array.from(Array(7).keys(),(days) => new Date(Date.now() - 86400000 * days));

Array.from({length:7},(_,days) => new Date(Date.now() - 86400000 * days));

生成随机ID

在原型设计时经常使用的创建ID功能。但是我在实际项目中看到有人使用它。其实这并不安全

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

取URL的查询参数

这个获取URL的查询参数代码,是我见过最精简的QAQ ?foo=bar&baz=bing => {foo: bar, baz: bing}

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

Object.fromEntries(new URLSearchParams(‘a=1&b=2’))

本地时间

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

// 创建本地时间

new Date().toLocaleTimeString()

数组混淆

随机更改数组元素顺序,混淆数组

// 随机更改数组元素顺序,混淆数组
(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)
*/

或者

function shuffle(arr) {
const newArr = […arr];
for (let i = 0, len = newArr.length; i < len; i += 1) {
const random = Math.floor(Math.random() * (i + 1));
if (i !== random){
[newArr[i], newArr[random]] = [newArr[random], newArr[i]];
}
}
return newArr;
}

或者

function shuffle(arr) {
let i = arr.length, j;
while (i) {
j = Math.floor(Math.random() * i–);
[arr[i], arr[j]] = [arr[j], arr[i]];
}
return arr;
}

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

使用JavaScript简洁代码生成随机十六进制代码

// before
‘#’ + Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, ‘0’);

// after
‘#’ + (0x1000000 + Math.random() * 0xffffff).toString(16).slice(1, 6);

Array.from({ length: 6 }, () => Math.floor(Math.random() * 16).toString(16)).join(“”)

一个面试题

这是一个臭名昭著的面试题,让你写出他的运行结果

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)]
// 或者
arr.filter((x, index, self) => self.indexOf(x) === index)

创建特定大小的数组

方便快捷创建特定大小的数组

// 创建一个数组
[…Array(3).keys()]

或者

Array.from({length: 3}, (val, i) => i)

返回一个键盘

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

// 用字符串返回一个键盘图形
(_=>[…”`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://dev.to

坚持技术创作分享,您的支持将鼓励我继续创作!